在nodejs中如何实现websocket通信功能

这篇文章主要介绍了nodejs结合socket.io实现websocket通信功能的方法,结合实例形式分析了nodejs结合socket.io实现websocket通信的具体步骤与相关操作技巧,需要的朋友可以参考下

本文实例讲述了nodejs结合socket.io实现websocket通信功能的方法。分享给大家供大家参考,具体如下:

因为项目中有需要实时获取后台数据的场景,之前一直是使用http心跳请求的方法。因为websocket与此模式相比有很大的性能提升,而且可以提高实时性,所以对websocket作了一些研究。这里是使用nodejs+socket.io来实现的。

达成目标

将原来心跳请求后台数据的方式,修改为通过socket连接后台统一推送的方式。后台的数据由别的进程写入文件或写入redis,这里实现的是读取文件的方式。

前期准备

安装nodejs(略)

服务器端

新建一个项目目录,这里是sockettest
进入sockettest目录,安装express模块和socketio模块

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

登录后复制

新建package.json文件,在其中写入如下内容:

  1. { "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文件,在其中写入内容:

  1. 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 

    新建data目录,并在下面新建两个文件trends与coins,用于存放socket服务器将要读取的数据。
    新建public目录,在其中新建一个文件index.html,文件内容如下:

        //新建socket    var socket = io('http://sockettest.com:3000');    socketdata(socket);    function socketdata() {      #定义接收到coins类型数据时的行为      socket.on('coins', function(msg){        console.log(msg);      }      #定义接收到trends类型数据时的行为      socket.on('trends', function(msg){        console.log(msg);      }    }
  2. 登录后复制

  3. 代码部署

  4. 刚才之所以要建两个index.html文件,是为了能够方便地在既有的web项目中使用nodejs提供的socket服务。这样我们把public/index.html可以部署在别的服务器中,比如nginxtomcat之类,然后在根目下启动socket的服务器,为其提供socket服务。
    首先在刚才的项目根目录下执行

  5. node ./trends.js
  6. 登录后复制

  7. 并保持终端运行,然后再把项目部署在nginx里,通过chrome下访问nginx提供的web服务:

  8. http://hostname/public/index.html

  9. 打开开发者模式,就能在console里看到每隔一秒便会收到来自node服务器的socket推送消息了。通过修改data目录下的两个文件,可以看到写入到文件的数据也会实时地推送到客户端这里来。

  10. 上面是我整理给大家的,希望今后会对大家有帮助。

  11. 相关文章:

  12. vue中使用cli如何实现重构多页面脚手架

  13. vue中使用cli如何实现重构多页面脚手架

  14. vue中使用cli如何实现重构多页面脚手架

  15. vue中使用cli如何实现重构多页面脚手架

  16. vue中使用cli如何实现重构多页面脚手架

  17. 以上就是在nodejs中如何实现websocket通信功能的详细内容,更多请关注【创想鸟】其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

点点赞赏,手留余香

给TA打赏
共0人
还没有人赞赏,快来当第一个赞赏的人吧!
    编程技术

    如何使用angular4共享组件通信

    2025-3-31 22:18:53

    编程技术

    微信小程序如何实现涂鸦

    2025-3-31 22:19:05

    0 条回复 A文章作者 M管理员
    欢迎您,新朋友,感谢参与互动!
      暂无讨论,说说你的看法吧
    个人中心
    购物车
    优惠劵
    今日签到
    私信列表
    搜索