AJAX不携带会话变量

时间:2013-03-06 18:21:07

标签: php ajax session

我有一个包含所有页面的集中索引页面。在这个索引页面中,我的会话开始了。我通过回显所有变量来测试它,它可以工作。

在AJAX php脚本上,我尝试调用会话变量,它似乎打印出任何东西:甚至不是会话ID。根据我的研究,你需要在AJAX脚本上调用session_start()。我这样做了,它启动了会话,但是使用了不同的ID,并且无法访问主网站上设置的会话变量。我没有在Google的前5页找到任何重复我的问题的内容。

如果我将'“。$ _ SESSION ['usr']。”'部分mysqli查询更改为我的用户名,则可以。这也证明事实上,AJAX脚本没有看到会话变量。

我能做些什么让AJAX脚本看到主网站上的会话而不是没有数据的会话?

代码:

AJAX:

$(document).ready(function(){

    // Moving North
    $('#moveNorth').on('click', function(){
        var value = $(this).text();
        $.ajax({
            url: "ajax/moveNorth.php",
            type: "POST",
            data: {data : value},
            cache: false,
            success: function(result) {
                 $('#coordinate-y').html(function(i, val) { return +val+1 });
            },
            error: function() {
                alert("Something went wrong. Please email an admin.");
            }
        });
     });
});

PHP脚本:

<?php

$sessionTest = session_id();//$_SESSION['usr'];

echo "Session Test | " . $sessionTest . " |";

$mysqli = new mysqli("db_host", "db_user", "db_password", "db_name");

if($mysqli->connect_errno)
{
    echo "Failed to connect to MySQL: (" . $mysqli->connect_errno . ") " . $mysqli->connect_error;
}
else
{
    $mysqli->query("UPDATE table_name SET coord_x = coord_x - 1 WHERE username = '".$_SESSION['usr']."'");
}

?>

页面调用AJAX:

<?php
$sessionTestID = session_id();//$_SESSION['usr']; 
echo $sessionTestID;
?>

0 个答案:

没有答案