PHP セッションが JQuery Ajax で動作しない場合?
質問
更新、解決済み:このすべての後、更新 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 で動作することが分かりました。
アップデート:より多くの情報を提供しようとしています。
ログインは正しく機能します。私のIDが認識され、私はそれをボードの隣に印刷して、それを正しく取得していることを確認しました。
AJAXリクエストはボードを更新します。合格した値は正しく、FireBugのコンソールで確認されます。ただし、ピースに属するプレイヤーのみを配置する代わりに、ピースはサイクルします(0,1,2)。
VoardUpdate.phpに手動で閲覧し、Ajaxから送信された同じ値を入力すると、エコーされた応答に見られる結果は、対応するピースが意図したとおりに毎回再生されることを示します。
Firefoxの新鮮な負荷後のラップトップで同じ結果。
手でログインすることなくBoardUpdate.phpに手動で閲覧すると、ボードを変更せずに残します(セッションでユーザーが見つからない場合)。
そのsession_start()がPHPファイル上にあることを再確認し、セッションID変数を再確認しました。
この追加情報がお役に立てば幸いです。何をお伝えすればよいかアイデアが尽きてきました。完全なコードをロードする必要がありますか?
更新 2:
fire-bug で Ajax の応答を確認したところ、「play」リクエストは結果を取得せず、ボードは次の「update」まで更新されないことがわかりました。まだ検討中ですが、皆さんのためにもここに投稿します。
ボードアップデート.php注目すべき場所は次のとおりです。リフレッシュボード(line6)place peact(line20)function boardupdate($ターンカウント)(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_dump
を入れて)そこにあることを確認するために$_SESSION
のdie
を行うだろう。それはあなたの本当の問題の嘘どこかということは非常に可能であり、セッションは、実際の作業であること。それがセッションを一掃させるが、例えば、あなたのログインコード、の問題はありませんか?
あなたのスクリプト以来、参考にすべきであるあなたのAJAX呼び出しの生の結果を見て Firebugのに使用することができます仕事に表示されますが、直接ページをご覧場合ます。
私は期待通りに動作しないセッションを見てきたケースが一般的session_start
があまりにも多くの場合、または遅すぎると呼ばれていることをされています。他の可能性は、あなたがめちゃくちゃ短いタイムアウトを持っているということですが、その音が低います。
最後に、あなたが使用クッキーセッションに設定されていることを確認してPHPをインストールすることを行うことができます。それはではないことをこの時点では非常に低いのですが、あなたは見ることができます。
他のヒント
の1つの潜在的な問題は、$.get
の使用である - サーバーのコードは毎回実行されませんので、それは、IEでキャッシュされます。 falseにキャッシュを設定して$.ajax
を使用してみてください。
$.ajax({
type: 'GET',
url: 'includes/boardControl.php',
cache: false,
data: {play: value, bid: bid}
});