对于聊天室,你们应该都不陌生,笔者也写过不少关于聊天室的例子。javascript
本节,咱们将演示如何经过Node.js来实现一个WebSocket聊天服务器的例子。html
Node.js原生API并未提供WebSocket的支持,所以,须要安装第三方包才能使用WebSocket功能。对于WebSocket的支持,在开源社区有很是多的选择,本例子采用的是“ws”框架(项目主页为https://github.com/websockets/ws)。java
“ws”顾名思义是一个用于支持WebSocket客户端和服务器的框架。它易于使用,功能强大,且不依赖于其余环境。node
想其余Node.js应用同样,使用ws的首选方式是使用npm来管理。如下命令行用于安装ws在应用里面:git
npm install ws
具有了ws包以后,就能够建立WebSocket服务器了。如下是建立服务器的j简单示例:github
const WebSocket = require('ws'); const server = new WebSocket.Server({ port: 8080 });
上述例子服务器启动在8080端口。web
聊天服务器的业务需求比较简单,是一个群聊聊天室。换言之,全部人发送的消息你们均可以见到。npm
当有新用户链接到服务器时,会以该用户的“IP+端口”做为用户的名称。浏览器
根据前面知识的学习,实现一个聊天服务器比较简单,完整代码以下:服务器
const WebSocket = require('ws'); const server = new WebSocket.Server({ port: 8080 }); server.on('open', function open() { console.log('connected'); }); server.on('close', function close() { console.log('disconnected'); }); server.on('connection', function connection(ws, req) { const ip = req.connection.remoteAddress; const port = req.connection.remotePort; const clientName = ip + port; console.log('%s is connected', clientName) // 发送欢迎信息给客户端 ws.send("Welcome " + clientName); ws.on('message', function incoming(message) { console.log('received: %s from %s', message, clientName); // 广播消息给全部客户端 server.clients.forEach(function each(client) { if (client.readyState === WebSocket.OPEN) { client.send( clientName + " -> " + message); } }); }); });
当客户端给服务器发送消息时,服务器会将该客户端的消息转发给全部客户端。
客户端是通HTML+JavaScript的方式实现的。因为浏览器原生提供了WebSocket的API,因此并不须要ws框架的支持。
客户端client.html文件代码以下:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>WebSocket Chat</title> </head> <body> <script type="text/javascript"> var socket; if (!window.WebSocket) { window.WebSocket = window.MozWebSocket; } if (window.WebSocket) { socket = new WebSocket("ws://localhost:8080/ws"); socket.onmessage = function (event) { var ta = document.getElementById('responseText'); ta.value = ta.value + '\n' + event.data }; socket.onopen = function (event) { var ta = document.getElementById('responseText'); ta.value = "链接开启!"; }; socket.onclose = function (event) { var ta = document.getElementById('responseText'); ta.value = ta.value + "链接被关闭"; }; } else { alert("你的浏览器不支持 WebSocket!"); } function send(message) { if (!window.WebSocket) { return; } if (socket.readyState == WebSocket.OPEN) { socket.send(message); } else { alert("链接没有开启."); } } </script> <form onsubmit="return false;"> <h3>WebSocket 聊天室:</h3> <textarea id="responseText" style="width: 500px; height: 300px;"></textarea> <br> <input type="text" name="message" style="width: 300px" value="Welcome to waylau.com"> <input type="button" value="发送消息" onclick="send(this.form.message.value)"> <input type="button" onclick="javascript:document.getElementById('responseText').value=''" value="清空聊天记录"> </form> <br> <br> <a href="https://waylau.com/">更多例子请访问 waylau.com</a> </body> </html>
首先启动服务器。执行下面的命令:
node index.js
接着用浏览器直接打开client.html文件,能够看到以下的聊天界面。
打开多个聊天窗口,就能模拟多个用户之间的群聊了。
本节例子能够在https://github.com/waylau/nodejs-book-samples的“ws-demo”应用中找到。
本节例子能够在“ws-demo”应用中找到。