4

更新,已解决: 毕竟我发现我在更新 ajax 中调用了旧版本的代码。'boardControl.php' 而不是 'boardUpdate.php' 这些是使编程变得有趣的错误类型。


我正在写一个浏览器五子棋游戏。我有允许玩家演奏一段的 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;

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

在我看来,当与 Ajax 一起使用时,会话并没有被延续。然而,谷歌搜索告诉我,会话确实适用于 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 值得注意的地方有: Refresh Board(line6) Place Piece(line20) function 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()


?>


请帮忙,如果需要,我很乐意提供更多信息。提前感谢=)

4

3 回答 3

5

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

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

我看到会话无法按预期工作的情况通常session_start是调用太频繁或太晚。另一种可能性是您的超时时间非常短,但这听起来不太可能。

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

于 2009-10-14T06:01:42.950 回答
2

此代码中的一个潜在问题是使用$.get- 它由 IE 缓存,因此您的服务器代码不会每次都运行。尝试使用$.ajax缓存设置为 false:

$.ajax({
  type: 'GET',
  url: 'includes/boardControl.php',
  cache: false,
  data: {play: value, bid: bid}
});
于 2009-10-14T05:53:53.513 回答
0

刚刚发生在我身上,在我的情况下,我正在使用 session_start 导入配置文件,并且由于我已经停用错误,我看不到导入从未发生过。只需三重检查,我知道这是基本的。

于 2021-05-05T17:09:43.067 回答