用node实现socketIO实时通信

一般来说只有前端才能向后端请求,请求完成后端再做出响应反馈给前端。而socket.io机制就解决了后端可以主动向前端发出请求,通过该原理即可实现聊天室的功能

第三方包的安装

首先应该安装socketio的第三方包,
客户端安装npm i socket.io-client
服务端安装: npm i socket.io

分别引入socket.io

客户端import io from 'socket.io-client'
服务端: require('socket.io')

服务端代码文件socketIO_server.js

module.exports = function (server) {
  const io = require('socket.io')(server)

console.log('okok');
  // 监视客户端与服务器的连接
  io.on('connection', function (socket) {
    console.log('有一个客户端连接上了服务器')

    // console.log('okok');
    // 绑定监听, 接收客户端发送的消息
    socket.on('sendMsg', function (data) {
      console.log('服务器接收到客户端发送的消息', data)
      // 处理数据
      data.name = data.name.toUpperCase()
      // 服务器向客户端发送消息
      // socket.emit('receiveMsg', data)
      io.emit('receiveMsg', data)
      console.log('服务器向客户端发送消息', data)
    })
  })
}```





客户端代码文件socketio_test.js

// 引入客户端IO
import io from 'socket.io-client'

// 连接服务器,得到代表连接的socket对象
const socket = io('ws://localhost:3000')

// 绑定'receiveMessage'的监听, 来接收服务器发送的消息 
socket.on('receiveMsg', function (data) {
    console.log('浏览器端接收到消息:', data)
})


// 向服务器发送消息
socket.emit('sendMsg', { name: 'Tom', date: Date.now() }) 
console.log('浏览器向服务器发送消息:',{name: 'Tom', date: Date.now() });

在客户端入口文件中引入 客户端配置的 socketio文件

import './test/socketio_test'

在服务端入口文件中引入 服务端配置的 socketio文件

 var http = require('http');
  var server = http.createServer(app);
   require('../socketIO/socketIO_server')(server)

效果显示:

控制台打印
在这里插入图片描述

浏览器端打印
在这里插入图片描述

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值