PHP会话不能使用JQuery Ajax?
更新,解决:
毕竟,我发现我在更新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}); }); }); value =董事会的平方位置 在为玩家识别创建用户登录之前,服务器端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,"p1"); $p2 = mysql_result($Result,"p2"); $newPiece = 0; //*default no player if($playerId == $p1) $newPiece = 1; if($playerId == $p2) $newPiece = 2; 出于某种原因,当我运行完整的Web应用程序时,即使在我删除代码以使它们循环之后,这些部分仍会循环. 在我看来,当与Ajax一起使用时,会话不会被转移.然而谷歌搜索告诉我,会话确实与Ajax一起工作. 更新:我正在尝试提供更多信息. >登录正常工作.我的 希望这些额外的信息有所帮助,我已经没有想法告诉你什么了.我应该加载完整的代码吗? 更新2: 在检查了火灾中的Ajax响应后,我意识到“播放”请求没有得到结果,并且在下一次“更新”之前电路板不会更新.我还在调查这个,但我也会在这里发布给你们. boardUpdate.php <?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,"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,"turn"); $boardState=mysql_result($Result,"boardstate"); $turnCount++; $playerId = $_SESSION['char']; $Query=("SELECT p1,p2 FROM board WHERE bid=$bid"); $Result=mysql_query($Query); $p1 = mysql_result($Result,"p1"); $p2 = mysql_result($Result,"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,"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,$slot) { if($slot == 0) {// echo $current,"+((","-",$old,")*9)"; return letter2Value($current)+(($new-$old)*9); } else if($slot == 1) {// echo $current,")*3)"; return letter2Value($current)+(($new-$old)*3); } else //slot == 2 {// echo $current,")"; 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,"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应该是你在每个页面上做的第一件事,你期望使用会话.之后,我会立即执行一个$_SESSION的var_dump来查看数据是否存在(在此之后放置一个模具).很可能你的真正问题出在其他地方,而且会话实际上正在发挥作用.您的登录代码是否存在问题,例如导致其消除会话的问题?
您可以使用Firebug查看AJAX调用的原始结果,这应该会有所帮助,因为如果您直接访问该页面,您的脚本似乎可以正常工作. 我看到会话不按预期工作的情况通常是session_start被调用太频繁或太晚.另一种可能性是你有一个疯狂的超时,但听起来不太可能. 最后,您可以确保将PHP安装设置为使用cookie会话.在这一点上它不太可能,但你可以看. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |