更新,解决:
毕竟,我发现我在更新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 =董事会的平方位置
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,"p1");
    $p2 = MysqL_result($Result,"p2");
    $newPiece = 0; //*default no player
    if($playerId == $p1)
        $newPiece = 1;
    if($playerId == $p2)
        $newPiece = 2;

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

在我看来,当与Ajax一起使用时,会话不会被转移.然而谷歌搜索告诉我,会话确实与Ajax一起工作.

更新:我正在尝试提供更多信息.

>登录正常工作.我的
ID被识别,我打印出来
在董事会旁边确保
我正确地检索它.
> ajax请求会更新
板.传递的值是
用firebug确认并确认
安慰.但不是放置
只为他们的球员的棋子
属于它循环虽然片断
州(0,1,2).
>手动浏览时
boardUpdate.PHP并放入
从Ajax发送的相同值
在回声反应中看到的结果
表示相应的
片断每次播放
意.
>之后我的笔记本上的结果相同
新鲜的firefox.
>手动浏览
boardUpdate.PHP没有登录
在离开董事会之前
没有变化(没有用户时的预期)
在会话中找到).
>我已经仔细检查了那个
session_start()在PHP文件上
并仔细检查会话ID
变量.

希望这些额外的信息有所帮助,我已经没有想法告诉你什么了.我应该加载完整的代码吗?

更新2:

在检查了火灾中的Ajax响应后,我意识到“播放”请求没有得到结果,并且在下一次“更新”之前电路板不会更新.我还在调查这个,但我也会在这里发布给你们.

boardUpdate.PHP
值得注意的地方是:
刷新板(第6行)
放置件(第20行)
function boardUpdate($turnCount)(第63行)

<?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会话.在这一点上它不太可能,但你可以看.

PHP会话不能使用JQuery Ajax?的更多相关文章

  1. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  2. 从iOS应用程序发送帖子到PHP脚本不工作…简单的解决方案就像

    我之前已经做了好几次了但是由于某些原因我无法通过这个帖子…我尝试了设置为_POST且没有的变量的PHP脚本……当它们未设置为发布时它工作精细.这是我的iOS代码:这里是PHP的一大块,POST变量不在正确的位置?我想这对于更有经验的开发人员来说是一个相当简单的答案,感谢您的帮助!解决方法$_POST是一个数组,而不是一个函数.您需要使用方括号来访问数组索引:

  3. 在IOS9中的Cordova应用程序使用JQuery / Javascript的window.history问题

    在两个测试用例中唯一改变的是Cordova.js.解决方法我看到这是几个星期前,但我会发布这个,以防其他人遇到它.听起来它可能与iOS9中的哈希更改生成的导航事件有关.如果是这样,可以将其添加到index.html以禁用哈希侦听:

  4. iOS 5上的jQuery事件

    解决方法在Apple开发论坛上由一个人回答:我需要在将元素添加到DOM之后才绑定(),如下所示:

  5. 应用程序关闭时的iOS任务

    我正在构建一个应用程序,通过ajax将文件上传到服务器.问题是用户很可能有时不会有互联网连接,并且客户希望在用户重新连接时安排ajax调用.这可能是用户在离线时安排文件上传并关闭应用程序.应用程序关闭时可以进行ajax调用吗?

  6. swift学习2 元组 tuples

    swift中出现了一种新的数据结构,非常牛掰的元组tuples如果懂PHP的猿,会发现这个元组和PHP的数组非常类似,同样是可以默认不指定key,也可以指定key目前的学习疑问是,如何进行元组的遍历?

  7. 尝试使用swift mailer,gmail smtp,php发送邮件

    这里是我的代码:在运行时出现此错误…

  8. Android – 将SQLite与MySQL同步的最佳方式

    参见英文答案>Synchronizingclient-serverdatabases5个我正在开发一个包含网络应用和移动应用程序的项目,该应用程序记录每日用户的数据.用户可以删除,更新他们的数据,他们可以使用许多设备插入数据.我打算这样开发:用户输入他们的数据然后插入sqlite.服务将定期启动(每5小时或每小时)以使用时间戳与MysqL同步.我确实在互联网上使用服务和时间戳搜索了一个样本,但我一

  9. android – Phonegap本地构建 – jquery ajax错误:readystate 0 responsetext status 0 statustext error

    解决方法您是否在索引文件中包含了内容安全元标记?

  10. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

随机推荐

  1. PHP个人网站架设连环讲(一)

    先下一个OmnihttpdProffesinalV2.06,装上就有PHP4beta3可以用了。PHP4给我们带来一个简单的方法,就是使用SESSION(会话)级变量。但是如果不是PHP4又该怎么办?我们可以假设某人在15分钟以内对你的网页的请求都不属于一个新的人次,这样你可以做个计数的过程存在INC里,在每一个页面引用,访客第一次进入时将访问时间送到cookie里。以后每个页面被访问时都检查cookie上次访问时间值。

  2. PHP函数学习之PHP函数点评

    PHP函数使用说明,应用举例,精简点评,希望对您学习php有所帮助

  3. ecshop2.7.3 在php5.4下的各种错误问题处理

    将方法内的函数,分拆为2个部分。这个和gd库没有一点关系,是ecshop程序的问题。会出现这种问题,不外乎就是当前会员的session或者程序对cookie的处理存在漏洞。进过本地测试,includes\modules\integrates\ecshop.php这个整合自身会员的类中没有重写integrate.php中的check_cookie()方法导致,验证cookie时返回的username为空,丢失了登录状态,在ecshop.php中重写了此方法就可以了。把他加到ecshop.php的最后面去就可

  4. NT IIS下用ODBC连接数据库

    $connection=intodbc_connect建立数据库连接,$query_string="查询记录的条件"如:$query_string="select*fromtable"用$cur=intodbc_exec检索数据库,将记录集放入$cur变量中。再用while{$var1=odbc_result;$var2=odbc_result;...}读取odbc_exec()返回的数据集$cur。最后是odbc_close关闭数据库的连接。odbc_result()函数是取当前记录的指定字段值。

  5. PHP使用JpGraph绘制折线图操作示例【附源码下载】

    这篇文章主要介绍了PHP使用JpGraph绘制折线图操作,结合实例形式分析了php使用JpGraph的相关操作技巧与注意事项,并附带源码供读者下载参考,需要的朋友可以参考下

  6. zen_cart实现支付前生成订单的方法

    这篇文章主要介绍了zen_cart实现支付前生成订单的方法,结合实例形式详细分析了zen_cart支付前生成订单的具体步骤与相关实现技巧,需要的朋友可以参考下

  7. Thinkphp5框架实现获取数据库数据到视图的方法

    这篇文章主要介绍了Thinkphp5框架实现获取数据库数据到视图的方法,涉及thinkPHP5数据库配置、读取、模型操作及视图调用相关操作技巧,需要的朋友可以参考下

  8. PHP+jquery+CSS制作头像登录窗(仿QQ登陆)

    本篇文章介绍了PHP结合jQ和CSS制作头像登录窗(仿QQ登陆),实现了类似QQ的登陆界面,很有参考价值,有需要的朋友可以了解一下。

  9. 基于win2003虚拟机中apache服务器的访问

    下面小编就为大家带来一篇基于win2003虚拟机中apache服务器的访问。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. Yii2中组件的注册与创建方法

    这篇文章主要介绍了Yii2之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

返回
顶部