用于显示数据库信息的ajax

时间:2012-09-07 09:58:19

标签: php ajax database monitoring

我有一个聊天使用Ajax的脚本,

我想做一个监控脚本,以便管理员可以看到用户之间的所有交流。

问题是我找不到任何解释如何从数据库接收数据而没有重新加载页面的脚本。

如果有人可以帮助我找到该脚本或给我一个构建它的教程,我会很高兴。

尽最大的尊重。

亲切的问候。

SP。

1 个答案:

答案 0 :(得分:1)

您正在使用ajax .. ajax的整个概念无需重新加载页面...

这项工作的最佳工具是:

  • 的WebSockets。减少开销。双向沟通。缺点:难以实施而不是跨浏览器
  • 服务器发送的事件。减少开销。 1路通信,无重复请求。缺点:不跨浏览器
  • 只是简单的ajax民意调查...效率低,开销更大,请求多,但它可以在任何地方使用。

Socket.io(为nodeJS编写)可能是最好的工作。它为您利用正确的传输(websockets,longpolling,服务器发送事件,flashsockets,ajax轮询),并为您提供最佳性能。

以下是几个php js实现示例:

使用服务器发送的DOM事件(not cross browser): 更新+/-每3秒

//javascript:
var source = new EventSource('updates.php');
source.onmessage = function (event) {
  console.log(event.data);
};

//php server side:
<?php
header("Content-Type: text/event-stream\n\n");
//..perform queries and put it in $data..
echo "data: " . json_encode($data) . "\n";
?>

使用jQuery ajax请求:每1000ms发送一次请求

//javascript: 
var interval_id = setInterval(function(){
    $.ajax({
      type: "POST",
      url: "updates.php",
      success: function(data){
        console.log("Data: ", data);
      }
    });
}, 1000); //last param is the interval time in ms

//php server side:
<?php
//..perform queries and put it in $data..
echo json_encode($data) . "\n";
?>

使用phpWebsockets:lib + codesample