PHP 会话无法与 JQuery Ajax 一起使用?
题
更新,已解决:毕竟我发现我在更新 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 一起使用时,会话不会被延续。然而 Google 搜索告诉我,会话确实可以与 Ajax 配合使用。
更新:我正在尝试提供更多信息。
登录工作正常。我的身份证已识别,我在板旁边将其打印出来,以确保我正确检索它。
AJAX请求确实更新了董事会。传递的值是正确的,并通过Firebug的控制台确认。但是,不仅将碎片放置在球员属于它的循环的情况下(0,1,2)。
当手动浏览到boardupdate.php并放入从ajax发送的相同值时,在回声响应中看到的结果表明,每次都按预期播放相应的部分。
新鲜的Firefox后,我的笔记本电脑上的结果相同。
手动浏览到boardupdate.php而无需登录之前,请在手动之前将板保持不变(如在会话中找不到用户时的意图)。
我仔细检查了该session_start()在PHP文件上,并仔细检查了会话ID变量。
希望这些额外的信息对您有所帮助,我已经不知道该告诉您什么了。我应该加载完整的代码吗?
更新2:
在检查了 fire-bug 中的 Ajax 响应后,我意识到“播放”请求没有得到结果,并且面板在下一次“更新”之前不会更新。我仍在研究这个问题,但我也会把它发布在这里给你们。
boardUpdate.php值得注意的地方有:刷新板(LINE6)位置件(LINE20)功能boardupdate($ thrcount)(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 调用的原始结果,这应该会有所帮助,因为如果您直接访问该页面,您的脚本似乎可以工作。
我见过的会话没有按预期工作的情况通常是这样的 session_start
呼叫太频繁或太晚。另一种可能性是你的超时时间非常短,但这听起来不太可能。
最后,您可以确保 PHP 安装设置为使用 cookie 会话。目前看来,这种情况不太可能发生,但你可以看看。
其他提示
这段代码中的一个潜在问题是使用 $.get
- 它由 IE 缓存,因此您的服务器代码不会每次都运行。尝试使用 $.ajax
将缓存设置为 false:
$.ajax({
type: 'GET',
url: 'includes/boardControl.php',
cache: false,
data: {play: value, bid: bid}
});