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应用平台.由于最近要开发一套人脸识别系统,对通讯效率的 ...
随机推荐
- Java如何执行操作系统的CMD命令行
在模拟cmd调用Python时遇到一些情况,这类问题可以归类为"超时,阻塞"等,问题原因: Process p=Runtime.getRuntime().exec(String[] ...
- 通过Maven发部项目的最实用配置
一.问题 我们平时开发项目,使用Maven或者Idea部署,尽可能是要做到自动化.一般情况下,做成自动化的方式有多种,下面简述我比较常用的3种. 二.解决方案一: (1)配置发部:使用IDEA自带的A ...
- 机甲大师S1机器人编程学习,Windows 10 安装Scratch和简单实例学习
机甲大师S1支持 Scratch 3.0以上版本. Scratch官方网址:https://scratch.mit.edu/ 最新版本为3.4.0 今天在Windows 10上,安装最新版本. 1. ...
- os.path.join()函数的用法
转:https://blog.csdn.net/hduxiejun/article/details/80289476 os.path.join()函数:连接两个或更多的路径名组件 1.如果各组件名 ...
- Object-C学习之NSSet和NSMutableSet
转自:http://blog.csdn.net/likandmydeer/article/details/7939749 一.简介 集合(set)是一组单值对象,它可以是固定的(NSSet).也可以是 ...
- i春秋——“百度杯”CTF比赛 九月场——Test(海洋cms / seacms 任意代码执行漏洞)
打开发现是海洋cms,那就搜索相关漏洞 找到一篇介绍海洋cms的命令执行漏洞的文章:https://www.jianshu.com/p/ebf156afda49 直接利用其中给出的poc /searc ...
- 实验吧——你真的会PHP吗?(intval范围 php中\00的利用)
题目地址:http://ctf5.shiyanbar.com/web/PHP/index.php 抓包在header中发现提示 访问得到源码 <?php $info = "" ...
- How to prove that SAP CRM WebUI is a stateful application
I create an enhancement in this function module to print out current session id: As long as I do not ...
- Solr搜索器的特性及相关操作
一.搜索处理器简介 所有的请求处理器都实现一个Java类,本例实现了solr.SearchHandler.在运行时,solr.SearchHandler被解析为内置的Solr类org.apache.s ...
- Vue组件间通信6种方式
摘要: 总有一款合适的通信方式. 作者:浪里行舟 Fundebug经授权转载,版权归原作者所有. 前言 组件是 vue.js 最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的 ...