Есть такое решение long polling
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type" />
<script type="text/javascript"
src="http://code.jquery.com/jquery-1.8.2.min.js"></script>
<script type="text/javascript" charset="utf-8">
var timestap = null;
function WaitForMsg()
{
$.ajax({
type: 'GET',
url: 'comet.php?timestamp='+ timestap,
async: true,
cache: false,
success: function(data){
var json = eval('('+ data + ')');
if (json["msg"]!="")
{
alert(json["msg"]);
}
timestap = json["timestamp"];
setTimeout('WaitForMsg()',1000);
},
error: function(XMLHttpRequest, textStatus, errorThrown){
// alert("Error: " + textStatus + "(" + errorThrown +")");
setTimeout('WaitForMsg()',15000);
}
});
}
$(document).ready(function(){
WaitForMsg();
});
</script>
<link type="text/css" rel="stylesheet" href="css/style.css" media="all">
<title>Comet</title>
</head>
<body>
</body>
</html>
$filename = dirname(__FILE__)."/data.txt";
$lastmodif = isset($_GET['timestamp']) ? $_GET['timestamp'] : 0;
$currentmodif = filemtime($filename);
while ($currentmodif <= $lastmodif)
{
usleep(10000);
clearstatcache();
$currentmodif = filemtime($filename);
}
$response = array();
$response['msg'] = file_get_contents($filename);
$response['timestamp'] = $currentmodif;
echo json_encode($response);
Какие тут есть минусы. 1. Запросы перестают идти через несколько минут после выхода со страницы. 2. Надо привязать базу данных, я знаю... mysql плохо работает с реальным временем, но надо какт это изменить