node websocket笔记

websocket事件

websocket可以监听的事件
服务端的事件connection、message、close等。。。。
客户端的事件open、message、close、error等四个事件

ws模块创建websocket

server.js

//引入ws模块
const WebSocket = require('ws');
const WebSocketServer = WebSocket.Server;
//创建socket服务器
const ws = new WebSocketServer({port:8080});
//开启监听
ws.on("connection", function (socket) {
	//监听收到的消息
    socket.on('message', function (msg) {
	   socket.send(msg);
	   console.log(msg);
    })
})

client.js

//引入ws模块
const WebSocket = require('ws')
//创建socket连接
const ws = new WebSocket('ws://192.168.1.202:8080')

// 打开连接之后的事件
ws.on('open', () => {
//给服务端发送字符串'hello'
  ws.send('Hello')
})

// 接受服务端发送的消息
ws.on('message', (message) => {
  console.log(message) // Hello
})

网页端监听
webAPI

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>socket</title>
	</head>
	<body>
		
	</body>
	<script type="text/javascript" src="/static/js/jquery.min.js"></script>
	<script type="text/javascript">
		(function(){
			//新建socket连接
			let ws = new WebSocket('ws://192.168.1.202:8080');
			//监听事件
			ws.addEventListener('open',function(e){
				ws.send("Hello WebSockets!");
			})
			//监听服务端发送回来的数据
			ws.addEventListener('message',function(e){
				console.log(e.data);
			})
		})(window);
	</script>
</html>

express和ws模块联动

只需要监听http服务就可以,不用监听app,express详细信息额外配置

const express = require('express');
const app = express();
var WebSocket = require('ws');
var http = require('http');
var server = http.createServer(app)
var ws = new WebSocket.Server({ server})

ws.on("connection", function (socket) {
    socket.on('message', function (msg) {
	   socket.send(msg);
	   console.log(msg);
    })
})

const port = 8080;


server.listen(port);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值