Citrix SD-WAN WANOP
ご意見をお寄せいただきありがとうございました

この記事は機械翻訳されています.免責事項

HTML5のしくみ

HTML5はHTTPを使用します。これはrequest/response クライアントとサーバー間の通信用のプロトコル。クライアントはTCP接続を開始し、それを使用してHTTP要求をサーバーに送信します。サーバーは、使用可能なリソースへのアクセス権を付与することにより、これらの要求に応答します。クライアントとサーバーが接続を確立した後、それらの間で交換されるメッセージにはWebSocketヘッダーのみが含まれ、HTTPヘッダーは含まれません。

HTML5のインフラストラクチャはWebSocketで構成されており、WebSocketは、既存のHTTPインフラストラクチャをさらに使用して、クライアントとWebサーバー間の通信のための軽量メカニズムを提供します。通常、WebSocketプロトコルはブラウザーとWebサーバーに実装します。ただし、このプロトコルは任意のクライアントまたはサーバーアプリケーションで使用できます。

クライアントがWebSockesを使用して接続を確立しようとすると、WebサーバーはWebSocketハンドシェイクをアップグレード要求として扱い、サーバーはWebSocketプロトコルに切り替えます。WebSocketプロトコルにより、ブラウザーとWebサーバー間の頻繁な対話が可能になります。したがって、このプロトコルは、株価指数やスコアカードなどのライブ更新、さらにはライブゲームにも使用できます。これは、クライアントブラウザとサーバー間の双方向の継続的な通信のためのオープン接続を維持しながら、サーバーが一方的な応答をクライアントに送信するための標準化された方法のために可能です。

また、Cometなどの他のさまざまなテクノロジーを使用して、標準化されていない方法でこの効果を実現することもできます。Cometの詳細については、http://en.wikipedia.org/wiki/Comet_(programming)を参照してください。

WebSocketプロトコルは、TCPポート80および443を介して通信します。これにより、ファイアウォールを使用してWeb以外のインターネット接続をブロックする環境での通信が容易になります。さらに、WebSocketには独自の断片化メカニズムがあります。WebSocketメッセージは、複数のWebSocketフレームとして送信できます。

サーバー上のWebアプリケーションがWebSocketをサポートしていない場合、WebSocketを使用することはできません。

HTML5がwebSocketセッションを確立する方法

HTML5をサポートするブラウザーは、JavaScriptAPIを使用して次のタスクを実行します。

  • WebSocket接続を開きます。

  • WebSocket接続を介して通信します。

  • WebSocket接続を閉じます。

WebSocket接続を開くために、ブラウザーはWebSocketプロトコルに切り替えるためのHTTPアップグレードメッセージをサーバーに送信します。サーバーは、この要求を受け入れるか拒否します。以下は、サンプルのクライアント要求とサーバー応答のスニペットです。

  • サンプルクライアントリクエスト

    pre codeblock GET /HTTP/1.1 Upgrade: websocket Sec-websocket-protocol: <List of protocols that the client supports over this websocket session, such as an application level protocol, for example ICA.> Sec-websocket-extensions: <List of extensions client wants applied to this session, such as compression.> Sec-Websocket-version: <Version of websocket protocol that the client intends to use.> <!--NeedCopy-->

  • サンプルサーバーの応答

    pre codeblock HTTP/1.1 101 Switching Protocols Upgrade: websocket Connection: Upgrade Sec-Websocket-Protocol: <One from the list of protocols in the client request.> Sec-Websocket-extensions: <List of extensions server accepts for session.> Sec-Websocket-version: <Version of websocket protocol that the server supports.> <!--NeedCopy-->

次の図は、クライアントとサーバー間で交換されるメッセージのシーケンスを示しています。

ローカライズされた画像

HTML5接続中に、次のメッセージがクライアントとサーバーの間で交換されます。

  • クライアントは、WebSocketをアップグレードするためのHTTPリクエストを送信します。
  • サーバーはクライアントの要求に応答し、WebSocketプロトコルに切り替えます。
  • サーバーはWebSocketフレームをクライアントに送信します。
  • クライアントは、WebSocketを閉じる要求を送信します。
  • サーバーはWebSocketを閉じます。
このコンテンツの正式なバージョンは英語で提供されています。Cloud Software Groupドキュメントのコンテンツの一部は、お客様の利便性のみを目的として機械翻訳されています。Cloud Software Groupは機械翻訳されたコンテンツを管理していないため、誤り、不正確な情報、不適切な用語が含まれる場合があります。英語の原文から他言語への翻訳について、精度、信頼性、適合性、正確性、またはお使いのCloud Software Group製品またはサービスと機械翻訳されたコンテンツとの整合性に関する保証、該当するライセンス契約書またはサービス利用規約、あるいはCloud Software Groupとのその他すべての契約に基づき提供される保証、および製品またはサービスのドキュメントとの一致に関する保証は、明示的か黙示的かを問わず、かかるドキュメントの機械翻訳された範囲には適用されないものとします。機械翻訳されたコンテンツの使用に起因する損害または問題について、Cloud Software Groupは責任を負わないものとします。
このサービスには、Google が提供する翻訳が含まれている可能性があります。Google は翻訳について、明示的か黙示的かを問わず、精度と信頼性に関するあらゆる保証、および商品性、特定目的への適合性、第三者の権利を侵害しないことに関するあらゆる黙示的保証を含め、一切保証しません。
HTML5のしくみ