会话登录设置为1,但在重定向时无法识别

时间:2018-10-04 20:24:00

标签: php jquery session

这是怎么了:

$('#btnlogin').click(function() {
    var uname = $('#inpuname').val().trim();
    var pass = $('#inpass').val().trim();
    $.post('ad-login-pro.php', {uname, pass}, function(data) {
        console.log(data); // result is 1
        if (data == 1) {location.href = 'ad-start.php';}
    });
});

ad-login-pro.php

$xuname = $_POST['uname'];
$xpass = $_POST['pass'];
$sql = "select status, uname, pass from users where uname = :auname and pass = :apass limit 1";
$st = $db->prepare($sql);
$st->execute([":auname" => $_POST['uname'], ":apass" => $_POST['pass']]);
$row = $st->fetch();
if ($row['uname'] == $xuname && $row['pass'] == $xpass) {
    $_SESSION['login'] = 1;
    $_SESSION['logstatus'] = $row['status'];
    echo $_SESSION['login'];
}

ad-start.php

if (!$_SESSION['login'] == 1) {header('location: ad-login.php');}

此行有效,即我要返回到ad-login.php

但是它不起作用,因为$_SESSION['login'] == 1;

有什么主意吗?

1 个答案:

答案 0 :(得分:0)

您应该尝试使用session_start()

示例:

ad-login-pro.php

// At the very top of the page
session_start();


$xuname = $_POST['uname'];
$xpass = $_POST['pass'];
$sql = "select status, uname, pass from users where uname = :auname and pass = :apass limit 1";
$st = $db->prepare($sql);
$st->execute([":auname" => $_POST['uname'], ":apass" => $_POST['pass']]);
$row = $st->fetch();
if ($row['uname'] == $xuname && $row['pass'] == $xpass) {
    $_SESSION['login'] = 1;
    $_SESSION['logstatus'] = $row['status'];
    echo $_SESSION['login'];
}

ad-start.php

// At the very top of the page
session_start();

if (!$_SESSION['login'] == 1) {header('location: ad-login.php');}

文档:http://php.net/manual/en/function.session-start.php