因此,我创建了一个可在localhost服务器上运行的登录页面。我想将它移动到一个实时网站,但我遇到了一个问题,代码不再工作了。我只包括php部分,因为用于登录信息的HTML表单可能不是问题。
<?php
session_start();
$_SESSION['errmsg'] = '';
if (isset($_POST['Username']) AND isset($_POST['Password'])) {
$username = $_POST['Username'];
$passwd = $_POST['Password'];
$stmt = $db->prepare("SELECT username, password, admin FROM Users WHERE username = :username AND password = :password;");
$stmt->bindValue(':username', "$username");
$stmt->bindValue(':password', "$passwd");
$stmt->execute();
$done = $stmt->fetch();
$affected_rows = $stmt->rowCount();
if ($affected_rows == 1) {
if ($done['admin'])
$_SESSION['admin_islogged'] = true;
$_SESSION['user_islogged'] = true;
$_SESSION['username'] = $_POST['Username'];
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
$_SESSION['id'] = $row['UserID'];
}
echo"<script>window.location = 'http://localhost/www/frontpage.php';</script>";
exit;
} else {
$_SESSION['errmsg'] = '<span style="background: red;text-color: white;">Error</span>';
}
}
echo "<span style='font-family:arial;color:white;font-size:18px'>{$_SESSION['errmsg']} </span>";
unset($_SESSION['errmsg']);
?>
frontpage.php目前在var_dump($ _ SESSION)上,在localhost上返回:
array (size=4)
'admin_islogged' => boolean false
'errmsg' => string '' (length=0)
'user_islogged' => boolean true
'username' => string 'Test' (length=4)
但在实际的实时服务器上,var_dump仅返回:
array(1) { ["admin_islogged"]=> bool(false) }
我不知道为什么会发生这种情况所以请赐教。
编辑:好的,所以我一直在var_dumping很多东西,我发现在我的登录页面上,var_dump($ _ SESSION)显示正确的东西,但当重定向到首页时,信息会发生变化。为什么会发生这种情况?答案 0 :(得分:0)
如果您希望使用会话,那么在输出或尝试使用会话变量之前,必须在您的页面顶部找不到session_start()
。
要使用基于cookie的会话,必须在向浏览器输出任何内容之前调用session_start()。
<?php
session_start();
$_SESSION['errmsg'] = '';
答案 1 :(得分:0)
只要设置了“admin_islogged”,会话就必须正常工作,所以问题出在某处
if ($done['admin'])
$_SESSION['admin_islogged'] = true;
你尝试使用普通括号,我真的不认为它应该修复它但是值得一试:
if ($done['admin']){
$_SESSION['admin_islogged'] = true;
}
编辑:做起来会更聪明:
$_SESSION['admin_islogged'] = $done["admin"];