从localhost移动到实时服务器时,Php登录中断

时间:2014-04-24 13:04:10

标签: php session login

因此,我创建了一个可在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)显示正确的东西,但当重定向到首页时,信息会发生变化。为什么会发生这种情况?

2 个答案:

答案 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"];