我是服务器发送事件的新手,并从w3网站复制了该教程示例。
html页面:
<html>
<body>
<div id="result"></div>
<script>
var source = new EventSource("sse.php");
source.onmessage = function(event) {
document.getElementById("result").innerHTML = event.data + "<br>";
};
</script>
</body>
</html>
php脚本:
<?php
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');
$time = date('r');
echo "data: The server time is: {$time}\n\n";
flush();
?>
这有效,页面每5秒更新一次。
我的问题是:为什么要5秒?这是SSE的默认设置,还是与php日期功能或某些php.ini设置有关?
编辑
我将php更改为此:
<?php
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');
while(true)
{
$time = date('r');
echo "data: The server time is: {$time}\n\n";
flush();
sleep(1);
}
?>
我什么也没得到,好像它在等待php脚本完成运行一样(永远不会)。
编辑2
PHP现在更改为此(包括建议的适当刷新):
<?php
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');
while(true)
{
$time = date('r');
echo "data: The server time is: {$time}\n\n";
while (ob_get_level() > 0)
ob_end_flush();
flush();
if (connection_aborted())
break;
sleep(1);
}
?>
仍然无所事事。