4

更新、解決済み: この後、更新ajaxで古いバージョンのコードを呼び出していることがわかりました。'boardUpdate.php'の代わりに'boardControl.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;

何らかの理由で、完全なWebアプリを実行すると、コードを削除して循環させた後でも、断片は循環します。さらに、ログイン後、ブラウザに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:

ファイアバグでAjaxの応答を確認した後、「play」リクエストは結果を取得せず、ボードは次の「update」まで更新されないことに気付きました。私はまだこれを調べていますが、皆さんのためにここに投稿します。

boardUpdate.php 注目すべき場所は次のとおりです。RefreshBoard(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、セッションを使用する予定の各ページで最初に行うことの 1 つであるということです。その後、すぐにvar_dumpofを実行$_SESSIONして、データがそこにあることを確認します (dieその後に右を置きます)。あなたの本当の問題は別の場所にあり、セッションが実際に機能している可能性は十分にあります。たとえば、ログイン コードに問題があり、それによってセッションが消去されていませんか?

Firebugを使用して、AJAX 呼び出しの生の結果を確認できます。これは、ページに直接アクセスするとスクリプトが機能しているように見えるため、役立つはずです。

私が見たセッションが期待どおりに機能しないケースは、一般に、session_start呼び出される頻度が高すぎるか遅すぎるというものです。もう 1 つの可能性は、タイムアウトが非常に短いことですが、それはありそうにないように思えます。

最後に、PHP インストールが Cookie セッションを使用するように設定されていることを確認できます。現時点ではそうではない可能性は非常に低いですが、見ることはできます。

于 2009-10-14T06:01:42.950 に答える
2

このコードの潜在的な問題の1つは、の使用$.getです。IEによってキャッシュされるため、サーバーコードが毎回実行されるわけではありません。$.ajaxキャッシュをfalseに設定して使用してみてください。

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