当前位置: 首页 > 面试题库 >

PHP会话不能与JQuery Ajax一起使用?

汤承德
2023-03-14
问题内容

解决的更新: 经过所有这些工作,我发现我正在更新ajax中调用代码的旧版本。“ boardControl.php”而不是“
boardUpdate.php”这些是使编程变得有趣的错误类型。

我正在写一个浏览器gomoku游戏。我有ajax声明,允许播放器演奏一曲。

$(document).ready(function() {
    $("td").live('click',function(){
        var value = $(this).attr('id');
        $.get('includes/boardControl.php',{play: value, bid: bid});
    });
});

值=木板面积位置
出价=木板ID

在创建用于标识玩家身份的用户登录名之前,服务器端php有一个临时解决方案。单击时会旋转方块的棋子状态,而不是知道要为其创建角色的玩家。

创建登录内容后,我为玩家的ID设置了一个会话变量。我希望在ajax请求期间从php中读取会话ID,并弄清楚他们来自哪里。

session_start();

    $playerId = $_SESSION['char'];
    $Query=("SELECT p1, p2 FROM board WHERE bid=$bid");
    $Result=mysql_query($Query);
    $p1 = mysql_result($Result,0,"p1");
    $p2 = mysql_result($Result,0,"p2");
    $newPiece = 0; //*default no player
    if($playerId == $p1)
        $newPiece = 1;
    if($playerId == $p2)
        $newPiece = 2;

由于某些原因,当我运行完整的Web应用html" target="_blank">程序时,即使我删除了使它们循环的代码,这些块仍会循环。此外,登录后如果我在浏览器中手动加载php页面,它将正确修改数据库(在该数据库中仅播放属于该播放器的片段)并输出正确的结果。

在我看来,与Ajax一起使用时,会话没有被保留。但是Google搜索告诉我,会话确实可以与Ajax一起使用。

更新:我正在尝试提供更多信息。

  1. 登录正常。我的ID被识别,我将其打印在板子旁边,以确保我正确地获取了它。

  2. ajax请求的确会更新开发板。传递的值正确,并已在firebug的控制台中确认。但是,虽然不是只为玩家放置棋子,但它们属于棋子,尽管棋子状态为(0,1,2)。

  3. 当手动浏览到boardUpdate.php并输入从Ajax发送来的相同值时,在回显响应中看到的结果表明每次都按预期播放了相应的乐曲。

  4. 重新加载Firefox后,在笔记本电脑上获得相同的结果。

  5. 手动浏览至boardUpdate.php而不登录,而无需手动登录以保持原样(如在会话中未找到用户时所期望的)。

  6. 我已经仔细检查了session_start()是否在php文件中,并仔细检查了会话ID变量

希望这些额外的信息能对您有所帮助,我用尽了所有建议。我应该加载完整的代码吗?

更新2:

在检查了Fire-bug中的Ajax响应后,我意识到“播放”请求没有得到结果,并且直到下一次“更新”时才更新板。我仍在调查此事,但我也会在这里为大家发布。

boardUpdate.php 值得注意的地方是:刷新Board(line6)放置Piece(line20)功能boardUpdate($
turnCount)(line63)

<?php
session_start();
require '../../omok/dbConnect.php';

    //*** Refresh Board ***
    if(isset($_GET['update']))
    {
        $bid = $_GET['bid'];
        $Query=("SELECT turn FROM board WHERE bid=$bid");
        $Result=mysql_query($Query);
        $turnCount=mysql_result($Result,0,"turn");

        if($_GET['turnCount'] < $turnCount) //** Turn increased
        {
            boardUpdate($turnCount);
        }
    }

    //*** Place Piece ***
    if(isset($_GET['play'])) // turn order? player detect?
    {
        $squareID = $_GET['play'];
        $bid = $_GET['bid'];

        $Query=("SELECT turn, boardstate FROM board WHERE bid=$bid");
        $Result=mysql_query($Query);
        $turnCount=mysql_result($Result,0,"turn");
        $boardState=mysql_result($Result,0,"boardstate");

        $turnCount++;

        $playerId = $_SESSION['char'];
        $Query=("SELECT p1, p2 FROM board WHERE bid=$bid");
        $Result=mysql_query($Query);
        $p1 = mysql_result($Result,0,"p1");
        $p2 = mysql_result($Result,0,"p2");
        $newPiece = 0; //*default no player
        if($playerId == $p1)
            $newPiece = 1;
        if($playerId == $p2)
            $newPiece = 2;

//      if($newPiece != 0)
//      {
            $oldPiece = getBoardSpot($squareID, $bid);
            $oldLetter = $boardState{floor($squareID/3)};
            $slot = $squareID%3;

            //***function updateCode($old, $new, $current, $slot)***
            $newLetter = updateCode($oldPiece, $newPiece, $oldLetter, $slot);
            $newLetter = value2Letter($newLetter);
            $newBoard = substr_replace($boardState, $newLetter, floor($squareID/3), 1);

            //** Update Query for boardstate & turn
            $Query=("UPDATE board SET boardState = '$newBoard', turn = '$turnCount' WHERE bid = '$bid'");
            mysql_query($Query);
//      }
        boardUpdate($turnCount);


    }

    function boardUpdate($turnCount)
    {
            $json = '{"turnCount":"'.$turnCount.'",';           //** turnCount **


            $bid = $_GET['bid'];
            $Query=("SELECT boardstate FROM board WHERE bid='$bid'");
            $Result=mysql_query($Query);
            $Board=mysql_result($Result,0,"boardstate");
            $json.= '"boardState":"'.$Board.'"';            //** boardState **


            $json.= '}';
            echo $json;
    }

    function letter2Value($input)
    {
        if(ord($input) >= 48 && ord($input) <= 57)
            return ord($input) - 48;
        else
            return ord($input) - 87;
    }

    function value2Letter($input)
    {
        if($input >= 10)
            return chr($input += 87);
        else
            return chr($input += 48);
    }


    //*** UPDATE CODE *** updates an letter with a new peice change and returns result letter.
    //***** $old : peice value before update
    //***** $new : peice value after update
    //***** $current : letterValue of code before update.
    //***** $slot : which of the 3 sqaures the change needs to take place in.
    function updateCode($old, $new, $current, $slot)
    {
        if($slot == 0)
        {// echo $current,"+((",$new,"-",$old,")*9)";
            return letter2Value($current)+(($new-$old)*9);
        }
        else if($slot == 1)
        {// echo $current,"+((",$new,"-",$old,")*3)";
            return letter2Value($current)+(($new-$old)*3);
        }
        else //slot == 2
        {// echo $current,"+((",$new,"-",$old,")";
            return letter2Value($current)+($new-$old);
        }
    }//updateCode()


    //**** GETBOARDSPOT *** Returns the peice value at defined location on the board.
    //****** 0 is first sqaure increment +1 in reading order (0-254).
    function getBoardSpot($squareID, $bid)
    {
        $Query=("SELECT boardstate FROM board WHERE bid='$bid'");
        $Result=mysql_query($Query);
        $Board=mysql_result($Result,0,"boardstate");


        if($squareID %3 == 2) //**3rd spot**
        {
            if( letter2Value($Board{floor($squareID/3)} ) % 3 == 0)
                return 0;
            else if( letter2Value($Board{floor($squareID/3)} ) % 3 == 1)
                return 1;
            else
                return 2;
        }
        else if($squareID %3 == 0) //**1st spot**
        {
            if(letter2Value($Board{floor($squareID/3)} ) <= 8)
                return 0;
            else if(letter2Value($Board{floor($squareID/3)} ) >= 18)
                return 2;
            else
                return 1;
        }
        else //**2nd spot**
        {
            return floor(letter2Value($Board{floor($squareID/3)}))/3%3;
        }
    }//end getBoardSpot()


?>

请帮助,如果需要,我很乐意提供更多信息。在此先感谢=)


问题答案:

从我们的一小段代码中,很难判断出您的问题可能是什么。我可以说的是,这session_start应该是您希望使用该会话的每个页面上要做的第一件事。在那之后,我将立即执行var_dumpof的操作$_SESSION以查看数据是否在其中(die在此之后放一个右)。您的真正问题很可能出在其他地方,并且该会话实际上正在运行。例如,您的登录代码是否有问题,导致其清除了会话?

您可以使用Firebug查看AJAX调用的原始结果,这会有所帮助,因为如果您直接访问该页面,脚本就可以正常工作。

我发现会话无法正常运行的情况通常session_start是因为调用频率太高或太晚。另一种可能性是您的超时时间非常短,但这听起来不太可能。

最后,您可以确保将PHP安装设置为使用cookie会话。在这一点上不太可能不会,但是您可以看一下。



 类似资料:
  • 问题内容: 首先,我是GAE的新手,所以可能我用错误的方式进行操作-但是我之前使用过PHP,而会话则是保持持久性数据的方式。我正在使用Python 2.7,因为这是我在所有其他Python开发中所使用的-尽管我开始怀疑降级到2.5是否是有效的解决方案,即使不是理想的解决方案。 场景是我正在建立一个概念验证站点,并且需要有一个“虚拟”登录按钮,该按钮仅将名为 “ user” 的会话变量设置为 “ a

  • 这是我为树莓pi编写的代码,它可以从树莓中获取一张静止的照片,并将其保存在一个目录中, 我已经给出了使用-R在forlder中读/写的所有权和权限,所以我在 /var/www的ls-al是这样的 是我试图将脚本作为类似于

  • 我试图用DataJpaTest注释测试我的存储库,但出现了一些奇怪的情况。 当我使用经典的时,一切正常,我的测试成功了。但是当我使用下面的生成器时,我的测试失败了。 测试应该成功,但其他测试没有成功,因为没有抛出关于约束有效性的异常。 例如,这里有一个失败的断言: Java语言AssertionError:预期测试将抛出org的实例。springframework。道。DataIntegrityV

  • 我的application.properties文件中有以下属性。 当我使用注释在spring控制器中使用属性时,它给我的值为2003,但当我通过获得它的值时,我获得的值为 如何使用AbstractenVironment获得值2003?

  • 问题内容: 我已经使用Selenium和最初的PhantomJS开发了一些Python脚本。在走向自动下载时,我改用了(带头的)Firefox(运行了),然后选择了无头选项的Chrome,这样我就不会打开浏览器了。 我的第一个脚本访问一个页面和几个HTML元素,与无头Chrome完美搭配。 但是第二个 仅适用于带头的Chrome 。如果添加“无头”选项,它将不再起作用。当我尝试以无头模式打印HTM

  • 问题内容: 我花了最后4个小时尝试在必须远程运行的Tomcat实例上设置Eclipse TPTP内存配置文件(即,不在Eclipse中运行)。根据TPTP和代理控制器文档,这应该是可能的。 根据网站上的指示,我将TPTP组件(4.6.0)与代理控制器一起安装到了Eclipse(Galileo)工作台中。为了启用代理,我在启动Tomcat实例的命令行中添加了以下选项: 并将以下目录添加到PATH的前