如何检查数据库是否使用php和ajax更新?

Muh*_*aid 4 php ajax chat

我正在制作一个聊天框,一切正常,除了更新的东西. 我目前每3秒刷新一次页面以检查任何新消息,但它肯定会导致服务器上的大量负载并且不优雅.

我想要的是,聊天框只会在数据库更新时检查新消息,而不是每隔3秒检查一次数据库的计时器

Not*_*aeL 6

您需要AJAX推送(服务器仅在有新内容时才将更新发送到客户端).请参阅此处的示例:http://provatosys.com/bid.html

这样的事情会详细说明来自客户的请求:

function sendRequest(uid){
    var xmlhttp;
    var myUserId="";
    myUserId=uid;

    if (window.XMLHttpRequest){// code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp=new XMLHttpRequest();
    } else { // code for IE6, IE5
        xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }

    xmlhttp.onreadystatechange=function(){
        if (xmlhttp.readyState==4 && xmlhttp.status==200){
            displayInChat(xmlhttp.responseText)//do stuff (process response, display message)
        }
    }

    xmlhttp.open("GET","process_request.php?userid="+uid,true);
    xmlhttp.send();

    setTimeout("sendRequest("+uid+")",1000); //poll every second
}
Run Code Online (Sandbox Code Playgroud)

现在,您希望延迟服务器的响应(process_request.php),直到有东西要发送(while (($msg=new_msgs()) === false) {sleep(timeout);}例如使用类似的东西)或请求超时,并从客户端发送新的轮询(setTimeout("sendRequest("+uid+")",timeoutinmillisecs);).这称为长轮询,对于像聊天这样的应用程序比使用空响应回复更有效.

您可以在此处找到更多信息:如何实施基本的"长轮询"?

在这里:让AJAX调用等待php中的事件

在这里:Comet(编程)

[编辑] 作为长轮询的一个非常需要和更有效的替代方法,现在所有主流浏览器都支持websockets.在RFC6455已经进入的(建议)标准的地位在2011年(这意味着它已退出草案状态,并没有因为任何的变化).PHP中最好的实现可能是Ratchet(据我所知,迄今为止最新的标准).这是一个如何使用它构建网络聊天的教程:http://socketo.me/docs/hello-world