sql >> Databasteknik >  >> RDS >> Mysql

Hämta nuvarande användar-id från databasen för att använda i ny tabell

Vad du kan göra är att spara användardata till sessionen

$_SESSION['user_data'] = $user->data();

du kan tilldela den tillbaka till $data när du kontrollerar $_SESSION['user_data'] är inställd, annars fråga modellen.

Och session_start() bör också vara överst i varje fil du vill hålla sessionen för.

Så något i stil med:

Profile.php

<?php
session_start();
require 'core/init.php';

if(!$username = Input::get('user')) {
    Redirect::to('index.php');
    exit;
}

if(!isset($_SESSION['user_data'])){
    $user = new User($username);

    if(!$user->exists()) {
        Redirect::to(404);
        exit;
    }

    $_SESSION['user_data'] = $user->data();
}
?>

<h3><?php echo escape($_SESSION['user_data']->username); ?></h3>
<p>Membership No: <?php echo escape($_SESSION['user_data']->id); ?></p>
<p>Full name: <?php echo escape($_SESSION['user_data']->name); ?></p>
<p>Date of birth: <?php echo escape($_SESSION['user_data']->dob); ?></p>
<p>Location: <?php echo escape($_SESSION['user_data']->location); ?></p>
<p>Join date: <?php echo escape($_SESSION['user_data']->joined); ?></p>

oerder.php

<?php
session_start();
require 'core/init.php';

if(!isset($_SESSION['user_data'])){
    Redirect::to('index.php');
    exit;
}

$Band_id = mysql_real_escape_string($_POST['band']);
$user_id = $_SESSION['user_data']->id;

$sql = "INSERT INTO orders (band_id,user_id) VALUES('$Band_id', '$user_id')";
mysql_query ($sql, $linkme)
or die ("could not add to database");
?>

Du bör också gå över till PDO eller mysqli.




  1. php mysql dubbelt datumintervall

  2. NLS_CHARSET_ID() Funktion i Oracle

  3. Behörighet nekades vid försök att importera en CSV-fil från PGAdmin

  4. Hur man escaper <,> och &tecken till html-enheter i Oracle PL/SQL