我尝试在我的应用程序中使用一些会话变量,但是,我无法让它们显示在我需要它们的页面上。
这是设置它们的代码(我也手动为它们分配了值,所以问题不是数据库拉取):
if ($name != ""){
$_SESSION['name'] = $name;
$_SESSION['id'] = $user_id;
}
我以 开始该页面session_start();
,就像在将使用会话变量的所有页面上一样。
当我尝试在另一个页面上调用会话变量时,它们不再存在,即使那是分配值重定向到的页面。
这就是我尝试调用会话变量的方式:
$name = $_SESSION['name'];
$user_id = $_SESSION['id'];
为什么要这样做?
编辑:为了帮助我包含该页面的其余代码。数据库连接部分工作正常,它们与我在其他地方使用的相同。
<?php
session_start();
define('DB_SERVER', '<server>');
define('DB_USER','<db>');
define('DB_PASSWORD' , '<password>');
define('DB_NAME' , '<db-name>');
$conn = new mysqli(DB_SERVER, DB_USER, DB_PASSWORD, DB_NAME) or
die('There was a problem connecting to the database');
$stmt = "Select User.user_id, User.name from User where User.username = '" .
$_POST["username"] . "' AND User.password = '" . $_POST["pwd"] . "';";
if(!$result = $conn->query($stmt)){
die('there was an error retrieving the information');
}
$row = $result->fetch_assoc();
$name = $row['name'];
$user_id = $row['user_id'];
$_SESSION["name"] = $name;
$_SESSION["id"] = $user_id;
if ($name != ""){
$conn->close();
?>
<script type="text/javascript">
<!--
window.location = "store.php"
//-->
</script>
<?php
}
else{
?>
<script type="text/javascript">
<!--
window.location = "register.php"
//-->
</script>
<?php
}
?>