NodeJs实现简单WebSocket即时通讯
⾄于服务器语⾔选择nodeJs,⼀是因为⾃⼰是做前端的,对javascript⽐较熟悉,相⽐于其他后台语⾔,⾃然会更喜欢nodeJs了,⼆是NodeJs本⾝事件驱动的⽅式很擅长与⼤量客户端保持⾼并发的连接。所以就选择NodeJs了。
服务器的实现很简单,先装⼀个nodeJs的模块,叫nodejs-websocket ,直接在nodeJs命令⾏中敲⼊:npm install nodejs-websocket回车就可以安装好了,
然后就可以开始建⽴服务器了,因为有了nodejs-websocket模块,所以很多⼯作都不⽤我们⾃⼰做,直接调⽤别⼈封装好的⽅法就⾏了:
服务端代码
根据客户端传来的消息判断哪个是game1,哪个是game2,保存connection对象。
var ws = require("nodejs-websocket");
html实现用户注册登录代码console.log("开始建⽴连接...")
var game1 = null,game2 = null , game1Ready = false , game2Ready = false;
var server = ws.createServer(function(conn){
<("text", function (str) {
console.log("收到的信息为:"+str)
if(str==="game1"){
game1 = conn;
game1Ready = true;
conn.sendText("success");
}
if(str==="game2"){
game2 = conn;
game2Ready = true;
}
if(game1Ready&&game2Ready){
game2.sendText(str);
}
conn.sendText(str)
})
<("close", function (code, reason) {
console.log("关闭连接")
});
<("error", function (code, reason) {
console.log("异常关闭")
});
}).listen(8001)
console.log("WebSocket建⽴完毕")
【game1代码】:通过点击获取三个框的内容,传到服务器
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.kuang{text-align: center;margin-top:200px;}
#mess{text-align: center}
.value{width: 200px;height:200px;border:1px solid;text-align: center;line-height: 200px;display: inline-block;}
</style>
</head>
<body>
<div id="mess">正在连接...</div>
<div class="kuang">
<div class="value" id="value1">⼩明⼩明</div>
<div class="value" id="value2">⼤胸⼤胸</div>
<div class="value" id="value3">⼩张⼩张</div>
</div>
<script>
var mess = ElementById("mess");
if(window.WebSocket){
var ws = new WebSocket('ws://192.168.17.80:8001');
console.log("连接服务器成功");
ws.send("game1");
}
console.log("服务器关闭");
}
console.log("连接出错");
}
mess.innerHTML = "连接成功"
document.querySelector(".kuang").onclick = function(e){
var time = new Date();
ws.send(time + " game1点击了“" + e.target.innerHTML+"”");
}
}
}
</script>
</body>
</html>
【game2代码】:获取服务推送来的消息,并且显⽰
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.kuang{text-align: center;margin-top:200px;}
#mess{text-align: center}
</style>
</head>
<body>
<div id="mess"></div>
<script>
var mess = ElementById("mess");
if(window.WebSocket){
var ws = new WebSocket('ws://192.168.17.80:8001');
console.log("连接服务器成功");
ws.send("game2");
}
console.log("服务器关闭");
}
console.log("连接出错");
}
var time = new Date();
mess.innerHTML+=time+"的消息:"+e.data+"<br>"
}
}
</script>
</body>
</html>
运⾏截图:
代码⾮常简单:很容易看懂,nodejs-WebSocket的调⽤也⾮常简洁明了,具体nodejs-websocket的API可以看,
⾥⾯都有介绍,⾃⼰测试⼀下,就很容易了,客户端的实现也是很简单,就通过onopen,onmessage等⼏个⽅法就可以实现了。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论