EventSource 是一種瀏覽器端的技術(shù),它允許服務(wù)器向客戶端推送實(shí)時(shí)更新。在 PHP 中,你可以使用 EventSource 來(lái)實(shí)現(xiàn)服務(wù)器端的推送功能。以下是一個(gè)簡(jiǎn)單的示例,展示了如何使用 PHP EventSource 進(jìn)行實(shí)時(shí)數(shù)據(jù)更新:
event_source.php
),并添加以下代碼:<?php
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');
// 獲取當(dāng)前時(shí)間并格式化為 ISO8601 格式
$time = date(DATE_ISO8601);
// 發(fā)送事件數(shù)據(jù)
echo "data: {$time}\n\n";
flush();
?>
這個(gè) PHP 腳本會(huì)設(shè)置正確的響應(yīng)頭,然后發(fā)送一個(gè)包含當(dāng)前時(shí)間的事件數(shù)據(jù)。flush()
函數(shù)用于清空輸出緩沖區(qū),確保數(shù)據(jù)立即發(fā)送到客戶端。
index.html
),并添加以下代碼:<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>EventSource Example</title>
</head>
<body>
<h1>EventSource Example</h1>
<p id="time"></p>
<script>
// 創(chuàng)建一個(gè) EventSource 對(duì)象,連接到 event_source.php
const eventSource = new EventSource('event_source.php');
// 監(jiān)聽服務(wù)器發(fā)送的消息
eventSource.onmessage = function (event) {
// 獲取事件數(shù)據(jù)
const data = event.data;
// 更新頁(yè)面上的時(shí)間顯示
document.getElementById('time').innerText = 'Server time: ' + data;
};
</script>
</body>
</html>
這個(gè) HTML 文件創(chuàng)建了一個(gè) EventSource
對(duì)象,連接到我們剛剛創(chuàng)建的 PHP 腳本。當(dāng)服務(wù)器發(fā)送消息時(shí),我們會(huì)更新頁(yè)面上的時(shí)間顯示。
index.html
。你應(yīng)該能看到實(shí)時(shí)更新的服務(wù)器時(shí)間。注意:確保你的 Web 服務(wù)器支持 PHP,并且已經(jīng)正確配置。此外,由于 EventSource 是基于 HTTP 長(zhǎng)連接的,因此在某些情況下可能會(huì)遇到跨域問(wèn)題。你需要確保服務(wù)器允許跨域請(qǐng)求,或者將客戶端和服務(wù)器部署在同一個(gè)域名下。