0

在我的 mysql 数据库中,我有一个名为 users 的表,它有一个名为 userID 的主键列,它是 Auto Increment 列。我想在会话数组中获取登录用户的该列的值,这是数组现在的样子:

array(4) { ["loggedIn"]=> bool(true) ["username"]=> string(9) "user" ["password"]=> string(3) "123" ["userID"]=> NULL }

这是我的登录表单的代码:

session_start();
$usr = new Users;
$usr->storeFormValues( $_POST );
if( $usr->userLogin() ) {
header( 'Location: cursos.php' ) ;
$_SESSION["loggedIn"] = true;
$_SESSION['username'] = $_POST['username'];
$_SESSION['password'] = $_POST['password'];
$_SESSION['userID'] = $_POST['userID'];

这是我的登录功能:

public function userLogin() {
$success = false;
try{
$con = new PDO( DB_DSN, DB_USERNAME, DB_PASSWORD );
$con->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
$sql = "SELECT * FROM users WHERE username = :username AND password = :password LIMIT 1";
$stmt = $con->prepare( $sql );
$stmt->bindValue( "username", $this->username, PDO::PARAM_STR );
$stmt->bindValue( "password", hash("sha256", $this->password . $this->salt), PDO::PARAM_STR );

$stmt->execute();

$valid = $stmt->fetchColumn();

if( $valid ) {
    $success = true;
}

$con = null;
return $success;

我需要的是在我的会话数组的末尾["userID"]=>从登录用户的表用户中获取列 userID 的值。这如何实现?如果有人可以提供帮助,我将不胜感激。谢谢你。

4

0 回答 0