検索
ホームページウェブフロントエンドH5 チュートリアルサーバーからのリアルタイムアップデートにHTML5サーバーセントイベント(SSE)APIを使用するにはどうすればよいですか?

サーバーからのリアルタイムアップデートのためにHTML5サーバーセントイベント(SSE)APIを使用する方法

HTML5サーバーセントイベント(SSE)APIは、Webサーバーがクライアントのブラウザにリアルタイムで更新をプッシュするためのシンプルで効率的な方法を提供します。 WebSocketsなどのテクノロジーとは異なり、SSEは単方向です。サーバーはクライアントにデータを送信しますが、クライアントは同じ接続を介してサーバーにデータを送信することはできません。このシンプルさにより、ストックティッカー、ライブスコア、チャットアプリケーション(クライアントがメッセージを受信する必要がある場合)など、サーバーがクライアントに更新をプッシュする必要があるシナリオに最適です。

SSEを使用するには、JavaScriptコードでEventSourceオブジェクトを作成する必要があります。このオブジェクトは、イベントをストリーミングするサーバー側のエンドポイントへの永続的な接続を確立します。これが基本的な例です。

 <code class="javascript">const eventSource = new EventSource('/events'); eventSource.onmessage = function(event) { console.log('Received event:', event.data); // Process the received data here, eg, update the UI }; eventSource.onerror = function(error) { console.error('EventSource failed:', error); };</code>

このコードは/eventsに接続されたEventSourceを作成します。 onmessageイベントハンドラーは、サーバーから送信されたデータを受信し、 onerrorハンドラーはエラーをキャッチします。サーバーは、AT /eventsを設定する必要があります。正しいSSE形式でデータを送信するように構成する必要があります(これについては、以下のサーバー側のセクションで詳しく説明します)。潜在的なエラーを処理し、再接続ロジックを実装することを忘れないでください(後のセクションで詳しく説明してください)。サーバーは、クライアントまたはサーバーのいずれかによって接続が閉じられるまで、この接続に対してデータを継続的に送信します。

WebSocketsのような他のリアルタイム通信技術と比較して、サーバーセントイベント(SSE)を使用することの利点

SSEは、WebSocketsのような他のリアルタイム通信技術よりもいくつかの利点を提供します。

  • シンプルさ: SSEは、クライアント側とサーバー側の両方で実装するのが大幅に簡単です。 APIは簡単で、プロトコルはWebSocketsよりも複雑ではありません。これにより、開発時間と複雑さが短縮されます。
  • 効率: SSEは、一方向の通信により効率的です。サーバーからクライアントへの通信のみを可能にするため、WebSocketsのような双方向通信プロトコルに関連するオーバーヘッドを回避します。これは、特に多くのクライアントを扱う場合、帯域幅の消費量の減少とサーバーの負荷の削減につながります。
  • HTTPベース: SSEは既存のHTTPインフラストラクチャを活用して、既存のWebサーバーやインフラストラクチャと簡単に統合できます。これにより、特殊なセットアップまたはプロトコルの必要性がなくなります。
  • 組み込みの再試行メカニズム: SSEには、組み込みの再試行メカニズムが含まれています。接続が失われた場合、クライアントは指定された遅延後に自動的にサーバーに再接続しようとします。これにより、エラー処理が簡素化され、堅牢性が保証されます。 (ただし、この動作をカスタマイズできますが)。

ただし、双方向通信が必要な場合、WebSocketは優れています。 SSEの単方向性は、クライアントがサーバーに積極的にデータを送信する必要があるシナリオでの適用性を制限します。

SSEクライアントアプリケーション内でエラー処理と再接続ロジックの実装

SSEには再試行メカニズムが組み込まれていますが、堅牢なアプリケーションは、より制御されたレスポンシブエクスペリエンスのために、カスタムエラー処理と再接続ロジックを実装する必要があります。これが強化された例です:

 <code class="javascript">const eventSource = new EventSource('/events'); let reconnectAttempts = 0; const maxReconnectAttempts = 5; eventSource.onmessage = function(event) { console.log('Received event:', event.data); reconnectAttempts = 0; // Reset on successful message }; eventSource.onerror = function(error) { console.error('EventSource failed:', error); if (reconnectAttempts  { eventSource.close(); eventSource = new EventSource('/events'); // Reconnect reconnectAttempts ; }, retryDelay); } else { console.error('Max reconnect attempts reached. Giving up.'); // Handle the failure appropriately, eg, display an error message to the user } };</code>

この改善された例が追加されます:

  • 再接続試行:無限のループを防ぐための再接続試行の数を制限します。
  • 指数バックオフ:試行ごとに指数関数的に再試行遅延を増加させ、接続問題中にサーバーの負荷を削減します。
  • 障害処理:再接続試行の最大数に達する状況を処理するメカニズムを提供します。

サーバー側のコードを構築して、サーバーセントイベント(SSE)APIを使用してイベントを効率的に送信する

SSEのサーバー側の実装は、使用されるテクノロジー(node.js、python、java)に依存します。ただし、コア原則は同じままです。サーバーは、正しいSSE形式でデータを送信する必要があります。この形式には、特定のHTTPヘッダー( Content-Type: text/event-stream )と特定のデリミターでフォーマットされたデータが必要です。 Expressを使用してnode.jsを使用した基本的な例を次に示します。

 <code class="javascript">const express = require('express'); const app = express(); const port = 3000; app.get('/events', (req, res) => { res.writeHead(200, { 'Content-Type': 'text/event-stream', 'Cache-Control': 'no-cache', 'Connection': 'keep-alive' }); // Simulate sending events every second setInterval(() => { const data = `data: ${new Date().toISOString()}\n\n`; res.write(data); }, 1000); req.on('close', () => { console.log('Client disconnected'); }); }); app.listen(port, () => { console.log(`Server listening on port ${port}`); });</code>

このnode.jsコードは/eventsでエンドポイントを設定します。 res.writeHead関数は、必要なHTTPヘッダーを設定します。 setInterval関数は、毎秒データを送信することをシミュレートします。重要なことに、各データメッセージの後に、SSE仕様で必要とされる2つのNewline文字( \n\n )が続きます。 req.on('close')イベントハンドラーは、切断を記録するために重要です。このコードを選択したサーバー側のテクノロジーとデータソースに適応させることを忘れないでください。効率的なスケーリングについては、ロードバランサーや非同期フレームワークなど、多くの同時接続を処理するために設計されたテクノロジーの使用を検討してください。

以上がサーバーからのリアルタイムアップデートにHTML5サーバーセントイベント(SSE)APIを使用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
HTMLオーディオとビデオの理解:属性とアクセシビリティHTMLオーディオとビデオの理解:属性とアクセシビリティMay 16, 2025 am 12:05 AM

html5audioandvideolementsEnnhancedActivitionAndAcsibilitySpecificAttributes.1)The'Controls'AttributeaddsStandardPlayBackControls、while'aria-label'improvesscreenreaderAcsibility.2)

マスタリングマイクロダタ:HTML5のステップバイステップガイドマスタリングマイクロダタ:HTML5のステップバイステップガイドMay 14, 2025 am 12:07 AM

MicrodatainHTML5enhancesSEOanduserexperiencebyprovidingstructureddatatosearchengines.1)Useitemscope,itemtype,anditempropattributestomarkupcontentlikeproductsorevents.2)TestmicrodatawithtoolslikeGoogle'sStructuredDataTestingTool.3)ConsiderusingJSON-LD

HTML5フォームの新しいものは何ですか?新しい入力タイプの調査HTML5フォームの新しいものは何ですか?新しい入力タイプの調査May 13, 2025 pm 03:45 PM

HTML5INTRODUCESNEWINPUTTYPESTENHANCEUSEREXPERIENCE、SIMPRIYIFYDEVELOPMENT、およびIMPROVEACCESSIBILITY.1)自動的にEmailformat.2)FOTIMIZENUMIMERICYPAD.3)およびSimplifyDateAndtimeInputs、reducingEdeDateDateRutedolutution。

H5の理解:意味と重要性H5の理解:意味と重要性May 11, 2025 am 12:19 AM

H5はHTML5、HTMLの5番目のバージョンです。 HTML5は、Webページの表現力と相互作用を向上させ、セマンティックタグ、マルチメディアサポート、オフラインストレージ、キャンバス描画などの新しい機能を導入し、Webテクノロジーの開発を促進します。

H5:アクセシビリティとWeb標準のコンプライアンスH5:アクセシビリティとWeb標準のコンプライアンスMay 10, 2025 am 12:21 AM

ネットワーク標準へのアクセシビリティとコンプライアンスは、Webサイトにとって不可欠です。 1)アクセシビリティは、すべてのユーザーがウェブサイトに平等にアクセスできるようにします。2)ネットワーク標準は、ウェブサイトのアクセシビリティと一貫性を改善するために続きます。3)アクセシビリティには、セマンティックHTML、キーボードナビゲーション、色コントラスト、代替テキストの使用が必要です。

HTMLのH5タグは何ですか?HTMLのH5タグは何ですか?May 09, 2025 am 12:11 AM

HTMLのH5タグは、小さいタイトルまたはサブタイトルのタグを付けるために使用される5番目のタイトルです。 1)H5タグは、コンテンツの階層を改良し、読みやすさとSEOを改善するのに役立ちます。 2)CSSと組み合わせて、スタイルをカスタマイズして視覚効果を強化できます。 3)H5タグを合理的に使用して、乱用を避け、論理コンテンツ構造を確保します。

H5コード:Web構造に関する初心者向けガイドH5コード:Web構造に関する初心者向けガイドMay 08, 2025 am 12:15 AM

HTML5にWebサイトを構築する方法には、次のものが含まれます。1。セマンティックタグを使用して、などのWebページ構造を定義します。 2。マルチメディアコンテンツ、使用、タグを埋め込みます。 3.フォーム検証やローカルストレージなどの高度な機能を適用します。これらの手順を通じて、明確な構造と豊富な機能を備えた最新のWebページを作成できます。

H5コード構造:読みやすさのためのコンテンツの整理H5コード構造:読みやすさのためのコンテンツの整理May 07, 2025 am 12:06 AM

合理的なH5コード構造により、ページは多くのコンテンツの中で際立っています。 1)コンテンツなどのセマンティックラベルを使用して、構造を明確にするためにコンテンツを整理します。 2)FlexBoxやグリッドなどのCSSレイアウトを介して、さまざまなデバイスでのページのレンダリング効果を制御します。 3)レスポンシブデザインを実装して、ページがさまざまな画面サイズに適応するようにします。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい