0

以下代码使网页加载大约 10 分钟,我不知道为什么!

function chatheartbeat(){
    include("config.php");
    $useradn = $_SESSION['displayname'];
    $query = "select * from chat where (userbdn = '".$useradn."' AND isread = 1) order by id ASC";
    $result = mysql_query($query , $link);
    $num_rows = mysql_num_rows($result);
    if ($num_rows >= 1) {
        $items = array();
        $i='1';
        while($chat = mysql_fetch_array($result)){
            $items[$i]['from']=$chat['useradn'];
            $items[$i]['msg']=$chat['msg'];
            $items[$i]['timee']=date("H:i" ,$chat['timee']);
            $i++;
        }
        $query = "update chat set isread = 0 where userbdn = '".$useradn."' and isread = 1";
        mysql_query($query , $link);
        header('Content-type: application/json');
        echo json_encode($items);
        exit;
    }else{
        sleep(2);
        chatheartbeat();
    }
}

有什么建议么?

4

3 回答 3

2

在第一次选择有一些结果之前,该函数永远不会返回。

我建议您在 n 次运行后返回(例如 5 次),即使没有结果。然后,客户端可以重新发出 ajax 调用以再次轮询。

此外,以递归方式执行此操作也不是一个好主意。我建议改为在 for 循环中执行此操作。

于 2013-03-01T20:46:30.757 回答
2

您正在递归地调用您的函数,并且由于会话变量在函数调用之间没有改变,如果它else第一次进入该部分,它每次都会去那里,创建一个永无止境的循环。

顺便说一句,如果你想使用轮询,你应该在客户端(javascript)中设置一个计时器,而不是在服务器端使用递归函数。

于 2013-03-01T20:44:23.260 回答
1

在执行任何长轮询技术时,您需要注意一些事项。

  1. 您需要在一些预定义的时间段后退出。在服务器上等待直到您有响应的内容会导致执行超时。

  2. 了解您的 SESSION 数据的情况。默认情况下,PHP 将使用基于文件的会话并在请求过程中锁定文件(除非您进行干预)

于 2013-03-01T20:47:17.397 回答