三种 socket 的实现方式

nodejs 下的 socket

服务端代码

const net = require('net')
const server = net.createServer() // 存储客户端对象
let clients = {}
let clentName = 0 server
.on('connection', client => {
client.name = ++clentName
clients[client.name] = client client
.on('data', msg => {
// 接受到客户端数据 广播数据
broadcast(client, msg)
})
}) .listen(3000); function broadcast(client, msg) {
for (let name in clients) { //向每个在线的客户端广播数据
clients[name].write(client.name + " says: " + msg) //发送数据使用 write 方法
}
}

客户端代码

const net = require('net')
const socket = new net.Socket() socket
.connect(3000, 'localhost', () => {
socket.write('hello1') //使用 write 方法发送消息 })
.on('data', msg => { //接收服务端消息
console.log(msg.toString());
})

WebSocket

服务端代码

const Ws = require('ws')
const ws = new Ws.Server({ //设置服务器地址
port: 3000,
host: 'localhost'
}) let clients = {}
let clientName = 0 ws.on('connection', client => {
client.name = ++clientName
clients[client.name] = client client.on('message', msg => { //监听 message 事件
broadcast(client, msg)
})
}) function broadcast(client, msg) {
for (let name in clients) {
clients[name].send(client.name + ' says: ' + msg) //使用send方法发送消息
}
}

客户端代码

const Ws = require('ws') // ie10+ 自带 WebSocket 对象
const ws = new Ws('ws://localhost:3000') //设置请求地址 scheme 为 ws ws
.on('open', () => { //连接成功
ws.send('hello1') //使用 send 方法向服务端发送消息
}) .on('message', msg => { //监听 message 事件接收服务端消息
console.log(msg);
})

socket.io

服务端代码

const path = require('path')
const ejs = require('ejs')
const http = require('http')
const express = require('express')
const IO = require('socket.io') const app = express()
const server = http.createServer(app)
const io = IO(server) io
.on('connection', socket => { // 有客户端接入
console.log('a user connected'); socket
.on('disconnect', () => {
console.log('a user disconnect');
})
.on('chat message', msg => { // 接收客户端消息 可自定义事件名
console.log('msg:', msg.toString());
io.emit('chat message', msg) // 向所有客户端发送消息
// socket.broadcast.emit('chat message', msg) // 向除此 socket 外的所有客户端广播消息 })
}) app
// 设置模版引擎
.set('views', path.join(__dirname, './view'))
.engine('html', ejs.renderFile)
.set('view engine', 'html')
// 渲染页面
.use('/', require('./router/view')) server
// 设置服务器地址
.listen(3000)

客户端代码

let socket = io() // 创建 socket 对象 需引入 socket.io.js
$('button').on('click',()=>{
socket.emit('chat message', $('#m').val())//发送消息
$('#m').val('')
})
socket
.on('chat message', msg=>{ //接收客户端广播消息
console.log(msg);
$('#messages').append($('<li>').text(msg))
})

三种实现方式的比较

  • nodejs 下的 socket

    需引入 nodejs 自带的 net 模块,浏览器端不可以直接使用

  • WebSocket

    大部分浏览器可直接使用,但 ie9 及其以下不兼容

  • socket.io

    可在浏览器使用,且兼容大部分浏览器,需引入 socket.io.js 文件

socket通信的三种实现方式的更多相关文章

  1. 不同vlan间通信的三种配置方式

    1.单臂路由(图) 环境:一台路由器,一台二层交换机,两台pc机 二层交换机的配置 //创建vlan 和 vlan : Switch(config)#vlan Switch(config-vlan)# ...

  2. 并发编程系列小结(线程安全,synchronized,脏读,线程间的通信wait/notify,线程的三种实现方式Demo,可替代wait/notify的方法)

    线程安全: 当多个线程访问某一个类(对象或方法)时,这个类始终都能表现出正确的行为,那么这个类(对象或方法就是线程安全的) synchronized: 可以在任意对象或方法上加锁,而加锁的这段代码称为 ...

  3. linux学习之centos(二):虚拟网络三种连接方式和SecureCRT的使用

    ---操作环境--- 虚拟机版本:VMware Workstation_10.0.3 Linux系统版本:CentOS_6.5(64位) 物理机系统版本:win10  一.虚拟网络三种连接方式 当在V ...

  4. VMware三种链接方式

    VMware三种链接方式 第一种:桥接Bridged 如其的说明:connected directly to the physical networkà直接连接到物理网络.如果是通过路由器连接出来的D ...

  5. Service组件 总结 + 绑定理Service三种实现方式 Messager + Binder + AIDL

    在Android中进程按优先级可以分为五类,优先级从高到低排列: - 前台进程 该进程包含正在与用户进行交互的界面组件,比如一个Activity - 可视进程 该进程中的组件虽然没有和用户交互,但是仍 ...

  6. Java之线程安全中的三种同步方式

    一个程序在运行起来时,会转换为进程,通常含有多个线程. 通常情况下,一个进程中的比较耗时的操作(如长循环.文件上传下载.网络资源获取等),往往会采用多线程来解决. 比如,现实生活中,银行取钱问题.火车 ...

  7. NBIoT三种部署方式【转】

    转自:https://472880.kuaizhan.com/89/34/p441944286fccf2 本文作者:吴老司撩通信 本文来源:EETOP NB-IoT支持在频段内(In-Band).保护 ...

  8. SignalR代理对象异常:Uncaught TypeError: Cannot read property 'client' of undefined 推出的结论 SignalR 简单示例 通过三个DEMO学会SignalR的三种实现方式 SignalR推送框架两个项目永久连接通讯使用 SignalR 集线器简单实例2 用SignalR创建实时永久长连接异步网络应用程序

    SignalR代理对象异常:Uncaught TypeError: Cannot read property 'client' of undefined 推出的结论   异常汇总:http://www ...

  9. Linux基石【第二篇】虚拟网络三种连接方式(转载)

    在虚拟机上安装完Centos系统后,开始配置静态IP,以方便在本宿主机上可以访问虚拟机,在曲折的配置中,了解到虚拟机还有三种连接方式:Bridged,NAT和Host-only,于是,我又一轮新的各种 ...

随机推荐

  1. MFC线程(二):线程同步临界区CRITICAL SECTION

    当多个线程同时使用相同的资源时,由于是并发执行,不能保证先后顺序.所以假如时一个公共变量被几个线程同时使用会造成该变量值的混乱. 下面来举个简单例子. 假如有一个字符数组变量 char g_charA ...

  2. 深入探究ASP.NET Core异常处理中间件

    前言     全局异常处理是我们编程过程中不可或缺的重要环节.有了全局异常处理机制给我们带来了很多便捷,首先我们不用满屏幕处理程序可能出现的异常,其次我们可以对异常进行统一的处理,比如收集异常信息或者 ...

  3. [USACO11JAN]Roads and Planes G【缩点+Dij+拓补排序】

    题目 Farmer John正在一个新的销售区域对他的牛奶销售方案进行调查.他想把牛奶送到T个城镇 (1 <= T <= 25,000),编号为1T.这些城镇之间通过R条道路 (1 < ...

  4. 让对象拥有状态——C#中的状态模式

    大家好,老胡又在博客和大家见面了,在聊今天的主角之前,老胡先给大家讲一个以前发生的故事.   真实的故事 当老胡还是小胡的时候,跟随团队一起开发一款游戏.这款游戏是一款末日生存类游戏,玩家可以 收集资 ...

  5. 泊车SLAM文献整理

    1. 泊车: 线车位检测 Geometric Features-Based Parking Slot Detection 译文链接:https://blog.csdn.net/djfjkj52/art ...

  6. tomcat发布时候jar包问题

    今天遇到个问题就是,启动tomcat时,报:java.lang.NullPointerException at org.apache.jsp.**_jsp.jspInit(index_jsp.java ...

  7. css input checkbox复选框控件 样式美化的多种方案

    checkbox复选框可能是网站中常用的html元素,但大多数人并不满意它的默认样式,这篇文章就讲讲如何实现input checkbox复选框控件 样式美化效果. 资源网站大全 https://55w ...

  8. 推荐一款ui架构--frozenui

    首页是这样定义的 移动框架 重磅出击 简单易用,轻量快捷,为移动端服务的前端框架 链接地址 http://frozenui.github.io/base.html#layout

  9. 选择困难症必看!云服务器如何选择操作系统,Windows和Linux哪个更好?

    在购买云服务器时,会有一个必选的配置,就是操作系统的选择,如何选择操作系统?操作系统选择错了怎么办?这是不少用户会遇到的问题,今天我们就来教大家如何选择操作系统,以及操作系统选择错了,该怎么切换. W ...

  10. kubernetes系列(十三) - 存储之Volume

    1. Volume简介 1.1 k8s的volume和docker的volume区别 1.2 kubernetes支持的volume类型 2. 重点的volume类型 2.1 emptyDir 2.1 ...