HTML5 - 开发一个自己的websocket服务器
应用:node.js
主要步骤:
- 创建文件夹
- 创建server.js(服务入口,server为自定义文件的命名)
- npm init -y (快速创建一个package.json文件)
- 依赖包安装:nodejs-websocket (github安装讲解)
- npm i nodejs-websocket
- 依赖包在appjs中的使用 (github how to use讲解)
https://github.com/sitegui/nodejs-websocket#how-to-use-it
配置完毕后启动:
命令行输入> node server.js (server这个名字不固定,具体看你的文件名叫啥)
服务端server.js 源码如下:
const ws = require('nodejs-websocket');//引入依赖包
const POST = 8080;//定义端口
// 创建一个server
const server = ws.createServer(connect => {
//每次只要有新的用户加入,就会为当前用户创建一个connect对象,同时调用一下这个回调函数。
console.log("New connection");
// text事件:接收用户请求,得到用户传输进来的数据。
connect.on("text", data => {
// 每当接受到用户请求事件,这个回调函数就会被触发。
console.log("Received "+data);
// sendText/send 方法:接受到请求后,响应一个数据给用户。因为是connect调用,所以只给当前connet对应的用户发送,如果需要给所有用户发送(广播),需要connections这个数组
connect.sendText(data.toUpperCase()+"!!!");//如果直接返回一个data,就会像echo那个服务器一样的功能,接收到什么就返回什么
});
// 连接断开 触发close事件
connect.on("close", (code, reason) => {
console.log("connection closed");
code && console.log(code);
reason && console.log(reason);
});
// error:监听服务异常事件,放置因报错而断掉整个服务。
connect.on('error', ()=>{
// 如果触发了close事件,就会走error异常事件(刷新也会),所以必须加error
console.log('连接出现异常');
});
});
server.listen(POST, ()=>{
console.log('webSocket服务启动成功了,监听了端口'+ POST);
});
客户端demo使用上述配置的服务器。 源码如下:
示例页面代码html:
<div class="demo">
<input type="text" placeholder="请输入要发送的内容" id="ipt">
<button id="btn">发送请求</button>
<p>
响应结果如下:
</p>
<div id="rst"></div>
<button id="closeBtn">断开连接</button>
</div>
示例页面代码js:
// var websocket = new WebSocket('ws://echo.websocket.org');// 使用ws官方提供的服务器
var websocket = new WebSocket('ws://localhost:8080'); // 使用我自己配置的服务器,前提要去websocketServer文件夹中把服务启动一下:node server.js
websocket.addEventListener('open', function (e) {
console.log(e, websocket.readyState);
// websocket.send('发送一个方法')
// websocket.send('xing.org1^')
btn.onclick = function (a) {
// console.log(a)
websocket.send(ipt.value);
}
});
// 接收返回值:
websocket.addEventListener('message', (e) => {
console.log(e);
rst.innerHTML = e.data;
});
closeBtn.onclick = function (e) {
console.log(e);
websocket.close(3000,'主动请求断开连接吧');//断开连接
}
websocket.addEventListener('close', function (e) {
console.log('连接断开了', e);
});
connections实现聊天室广播:
即给所有的用户(server.connections)都发送消息(sendText):
function broadcast(server, msg) {// 广播函数
server.connections.forEach(function (conn) {
conn.sendText(msg)
})
}
具体实现方案,见下篇:《websocket的应用 - 实现一个简易的聊天室效果。》
HTML5 - 开发一个自己的websocket服务器的更多相关文章
- 自己动手模拟开发一个简单的Web服务器
开篇:每当我们将开发好的ASP.NET网站部署到IIS服务器中,在浏览器正常浏览页面时,可曾想过Web服务器是怎么工作的,其原理是什么?“纸上得来终觉浅,绝知此事要躬行”,于是我们自己模拟一个简单的W ...
- Step by Step 使用HTML5开发一个星际大战游戏(1)
本系列博文翻译自以下文章 http://blog.sklambert.com/html5-canvas-game-panning-a-background/ Languages: HTML5, Jav ...
- Step by Step 使用HTML5开发一个星际大战游戏(2)
HTML5 Canvas Game: 玩家飞船 本系列博文翻译自以下文章 http://blog.sklambert.com/html5-canvas-game-the-player-ship/ L ...
- 实现一个websocket服务器-理论篇
本文是Writing WebSocket servers的中文文档,翻译自MDNWriting WebSocket servers.篇幅略长,个人能力有限难免有所错误,抛砖引玉共同进步. websoc ...
- 根据Unix哲学来编写你的HTML5 Websocket服务器来实现全双工通信
websocketd代表WebSocket的守护进程 websocketd处理的是浏览器和服务器之间的WebSocket连接,它会启动你所指定的服务器端应用来对WebSockets进行处理,然后在浏览 ...
- 如何实现websocket服务器-理论篇
WebSocket 服务器简单来说就是一个遵循特殊协议监听服务器任意端口的tcp应用.搭建一个定制服务器的任务通常会让让人们感到害怕.然而基于实现一个简单的Websocket服务器没有那么麻烦. 一个 ...
- 谈谈如何使用Netty开发实现高性能的RPC服务器
RPC(Remote Procedure Call Protocol)远程过程调用协议,它是一种通过网络,从远程计算机程序上请求服务,而不必了解底层网络技术的协议.说的再直白一点,就是客户端在不必知道 ...
- Netty开发实现高性能的RPC服务器
Netty开发实现高性能的RPC服务器 RPC(Remote Procedure Call Protocol)远程过程调用协议,它是一种通过网络,从远程计算机程序上请求服务,而不必了解底层网络技术的协 ...
- 自己动手,开发轻量级,高性能http服务器。
前言 http协议是互联网上使用最广泛的通讯协议了.web通讯也是基于http协议:对应c#开发者来说,asp.net core是最新的开发web应用平台.由于最近要开发一套人脸识别系统,对通讯效率的 ...
随机推荐
- ReentrantLock和Condition实现生产者和消费者
一个生产者和一个消费者 public class ConditionTest { private static ReentrantLock lock = new ReentrantLock(); pr ...
- Kubernetes Nacos
一.概览 Nacos 是阿里巴巴推出来的一个新开源项目,这是一个更易于构建云原生应用的动态服务发现.配置管理和服务管理平台. Nacos 致力于帮助您发现.配置和管理微服务.Nacos 提供了一组简单 ...
- 适配器模式(Adapter Pattern)--设计模式
在生活中,想用苹果充电线给安卓的手机充电时,因为两者的接口不一样,会导致充电口无法进行匹配, 这时候,就需要适配器,将安卓的充电口转化为苹果的接口,这样就可以充电啦.已有的类与新的接口不兼容问题是很普 ...
- 深入V8引擎-AST(5)
懒得发首页了,有时候因为贴的代码太多会被下,而且这东西本来也只是对自己学习的记录,阅读体验极差,所以就本地自娱自乐的写着吧! 由于是解析字符串,所以在开始之前介绍一下词法结构体中关于管理字符串类的属性 ...
- Java向MySQL新增记录时间误差问题
参考文档 https://www.jianshu.com/p/115861aad147 https://blog.csdn.net/ai932820942/article/details/845804 ...
- .net 中访问config的一些方式
人所缺乏的不是才干而是志向,不是成功的能力而是勤劳的意志. 哎!好久没有写博客了,今天就分享一些比较常用的对config文件的访问一些方式. 首先 引用 using System.Configurat ...
- 洛谷 p1387最大正方形
洛谷 p1387最大正方形 题目描述 在一个n*m的只包含0和1的矩阵里找出一个不包含0的最大正方形,输出边长. 输入格式 输入文件第一行为两个整数n,m(1<=n,m<=100),接下来 ...
- 写css注意的事项
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- iOS编程
一.语法 1. performSelector 2.
- Kotlin开发springboot项目(二)
Kotlin开发springboot项目(二) 中文学习网站: https://www.kotlincn.net/ 研究一下kotlin的demo: https://github.com/JetBra ...