ホームページ  >  記事  >  ウェブフロントエンド  >  nodejsはsocket.ioを組み合わせてWebSocket通信機能を実装します

nodejsはsocket.ioを組み合わせてWebSocket通信機能を実装します

小云云
小云云オリジナル
2018-01-15 09:17:411665ブラウズ

この記事では、websocket通信機能を実現するためにnodejsとsocket.ioを組み合わせる方法を主に紹介し、websocket通信を実現するためにnodejsとsocket.ioを組み合わせる具体的な手順と関連する操作スキルをサンプルの形で分析します。皆さんの参考になれば幸いです。

プロジェクトにはバックグラウンド データのリアルタイム取得が必要なシナリオがあるため、以前は http ハートビート リクエスト メソッドが使用されていました。 WebSocket はこのモードと比較してパフォーマンスが大幅に向上し、リアルタイム パフォーマンスを向上させることができるため、WebSocket についていくつかの研究が行われています。これは、nodejs+socket.io を使用して実装されます。

目標達成

バックグラウンドデータのハートビートリクエストの独自方式を、バックグラウンドへのソケット接続による統合プッシュ方式に変更しました。バックグラウンド データは、他のプロセスによってファイルまたは Redis に書き込まれます。ここで実装されるのは、ファイルを読み取る方法です。

準備

nodejsをインストール(省略)

サーバー側

新しいプロジェクトディレクトリを作成、ここにsockettestがあります
sockettestディレクトリに入り、expressモジュールとsocketioモジュールをインストールします


npm install --save express@4.10.2
npm install --save socket.io

新しい package.json ファイルを作成し、その中に次のコンテンツを書き込みます:


{
 "name": "socket-test",
 "version": "0.0.1",
 "description": "my first socket.io app",
 "dependencies": {
  "express": "^4.10.2",
  "socket.io": "^1.7.2"
 }
}

新しいindex.html。デフォルトのアクセス表示ページとして使用されます。ここでは使用されないため、コンテンツは任意です。新しい Trends.js ファイルにコンテンツを書き込みます:


var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
var fs = require('fs');
#默认打开文件
app.get('/', function(req, res){
  res.sendfile('index.html');
});
#用于存储所有socket以广播数据
var iolist = [];
#定义socket on connection(连入)事件行为
io.on('connection', function(socket){
  #将连入socket加入列表
  iolist.push(socket); 
  #记录index,在disconnect(断开连接)发生时将对应的socket删除
  var sockex = iolist.indexOf(socket); 
  #定义on disconnect事件行为
  socket.on('disconnect', function(){
    #将断开连接的socket从广播列表里删除
    iolist.splice(sockex, 1);
  });
});
# 数据广播进程:每1秒钟广播一次
setInterval(function() {
  # 如果没有正在连接的socket,直接返回;
  if (iolist.length <= 0) return;
  var trends = fs.readFileSync(&#39;./data/trends.json&#39;,&#39;utf-8&#39;);#trends数据
  var coins = fs.readFileSync(&#39;./data/coins.json&#39;,&#39;utf-8&#39;);#coins数据
  #向所有socket连接发送数据
  for (i in iolist) {
    # 向客户端发送trends数据
    iolist[i].emit(&#39;trends&#39;, trends);
    # 向客户端发送coins数据
    iolist[i].emit(&#39;coins&#39;, coins);
  }
}, 1000);
# 服务器侦听在sockettest.com的3000端口上
http.listen(3000, function(){
  # 输出到标准输出
  console.log(&#39;listening on sockettest.com:3000&#39;);
});

新しいデータ ディレクトリを作成し、以下の 2 つの新しいファイル トレンドとコインを作成して、ソケット サーバーによって読み取られるデータを保存します。

新しいパブリックディレクトリを作成し、その中に新しいファイルindex.htmlを作成します。ファイルの内容は次のとおりです:


<!--引入必要的js文件-->
<script type="text/javascript" src="http://sockettest:3000/socket.io/socket.io.js"></script>
<script type="text/javascript">
    //新建socket
    var socket = io(&#39;http://sockettest.com:3000&#39;);
    socketdata(socket);
    function socketdata() {
      #定义接收到coins类型数据时的行为
      socket.on(&#39;coins&#39;, function(msg){
        console.log(msg);
      }
      #定义接收到trends类型数据时的行为
      socket.on(&#39;trends&#39;, function(msg){
        console.log(msg);
      }
    }
</script>

コードデプロイメント

index.htmlを2つ作成した理由ファイルは、既存の Web プロジェクトが、nodejs によって提供されるソケット サービスを使用しやすくするために使用されます。このようにして、nginx や tomcat などの他のサーバーに public/index.html をデプロイし、ルート ディレクトリでソケット サーバーを起動してソケット サービスを提供できます。

まず、先ほどのプロジェクトのルート ディレクトリで


node ./trends.js

を実行し、ターミナルを実行したままにして、プロジェクトを nginx にデプロイし、Chrome 経由で nginx が提供する Web サービスにアクセスします:

http://hostname/ public /index.html

開発者モードをオンにすると、ノードサーバーからソケットプッシュメッセージを毎秒受信することがコンソールに表示されます。データ ディレクトリ内の 2 つのファイルを変更すると、ファイルに書き込まれたデータもリアルタイムでクライアントにプッシュされることがわかります。

関連する推奨事項:


HTML5でのWebSocket通信

Ajaxと組み合わせたThinkPHP、クライアント通信関数のMysql実装コード例

JSページ間の通信メソッドのストレージイベントの紹介

以上がnodejsはsocket.ioを組み合わせてWebSocket通信機能を実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。