WebSocket およびその他のリバース Ajax テクノロジーの概要
リアルタイム Web アプリケーションでは、一般的な方法は逆 Ajax です。逆 Ajax の定義:
Reverse Ajax (リバース Ajax) は、本質的にサーバーからクライアントにデータを送信できる概念です。標準の HTTP Ajax リクエストでは、データがサーバーに送信されます。リバース Ajax は、いくつかの特定の方法で Ajax リクエストをシミュレートできます。この方法で、サーバーはデータをサーバーに送信できます。クライアントはイベントを送信します (低遅延通信)。
リバース Ajax テクノロジーには主に 2 つの内容があります。1 つはクライアントに送信するデータが得られるまでサーバーが TCP 接続を維持すること (ループとスリープを使用して実装可能)、もう 1 つはクライアントの JS プログラミング スキルです。
Websocket は HTML5 の標準であり、反 Ajax テクノロジでもあります。
リバース AJAX テクノロジーの Socket.io 実装例
socket.io 公式紹介:
Socket.IO は、さまざまなトランスポート メカニズム間の違いを曖昧にし、あらゆるブラウザーでリアルタイム接続を提供することを目的としています。 IO は、API に影響を与えることなく、実行時に最も能力のあるトランスポートを選択します。 WebSocket Adobe® Flash® Socket AJAX ロング ポーリング AJAX マルチパート ストリーミング Forever Iframe JSONP ポーリング
簡単に言うと、socket.io は、複数のリバース Ajax テクノロジーをパッケージ化し、インターフェイスを統合する、nodejs をベースにしたライブラリです。実行時に、socket.io はブラウザの条件に基づいて、socket.io サーバーと対話するための適切なリバース Ajax テクノロジーを自動的に選択します。 WebSocket などのテクノロジーが標準であれば、socket.io はアプリケーションです。
インストール方法は次のとおりです (著者は Linux Mint 16 を使用しています):
node.js をインストールします:
npm をインストールします:
socket.io の例
次の例は公式 Web サイトからのものであり、適切に変更されています。
最初にサーバー側 (サーバー側) コード (ファイル test.js) を作成します。
io.sockets.on('接続', function (socket) {
socket.emit('ニュース', { hello: 'world' });
socket.on('私の他のイベント' 、 function (data) {
console.log(data);
});
});
著者はポート 80 を使用する nginx サーバーを構築し、Web ルート ディレクトリは /usr/share/nginx/html です。 ~/node_modules/socket.io/node_modules/socket.io-client/dist の下にあるsocket.io.min.jsをWebルートディレクトリにコピーし、Webルートディレクトリにファイルindex.phpを作成します(クライアントとして)。内容は次のとおりです: