应用: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服务器的更多相关文章

  1. 自己动手模拟开发一个简单的Web服务器

    开篇:每当我们将开发好的ASP.NET网站部署到IIS服务器中,在浏览器正常浏览页面时,可曾想过Web服务器是怎么工作的,其原理是什么?“纸上得来终觉浅,绝知此事要躬行”,于是我们自己模拟一个简单的W ...

  2. Step by Step 使用HTML5开发一个星际大战游戏(1)

    本系列博文翻译自以下文章 http://blog.sklambert.com/html5-canvas-game-panning-a-background/ Languages: HTML5, Jav ...

  3. Step by Step 使用HTML5开发一个星际大战游戏(2)

    HTML5 Canvas Game: 玩家飞船  本系列博文翻译自以下文章 http://blog.sklambert.com/html5-canvas-game-the-player-ship/ L ...

  4. 实现一个websocket服务器-理论篇

    本文是Writing WebSocket servers的中文文档,翻译自MDNWriting WebSocket servers.篇幅略长,个人能力有限难免有所错误,抛砖引玉共同进步. websoc ...

  5. 根据Unix哲学来编写你的HTML5 Websocket服务器来实现全双工通信

    websocketd代表WebSocket的守护进程 websocketd处理的是浏览器和服务器之间的WebSocket连接,它会启动你所指定的服务器端应用来对WebSockets进行处理,然后在浏览 ...

  6. 如何实现websocket服务器-理论篇

    WebSocket 服务器简单来说就是一个遵循特殊协议监听服务器任意端口的tcp应用.搭建一个定制服务器的任务通常会让让人们感到害怕.然而基于实现一个简单的Websocket服务器没有那么麻烦. 一个 ...

  7. 谈谈如何使用Netty开发实现高性能的RPC服务器

    RPC(Remote Procedure Call Protocol)远程过程调用协议,它是一种通过网络,从远程计算机程序上请求服务,而不必了解底层网络技术的协议.说的再直白一点,就是客户端在不必知道 ...

  8. Netty开发实现高性能的RPC服务器

    Netty开发实现高性能的RPC服务器 RPC(Remote Procedure Call Protocol)远程过程调用协议,它是一种通过网络,从远程计算机程序上请求服务,而不必了解底层网络技术的协 ...

  9. 自己动手,开发轻量级,高性能http服务器。

    前言 http协议是互联网上使用最广泛的通讯协议了.web通讯也是基于http协议:对应c#开发者来说,asp.net core是最新的开发web应用平台.由于最近要开发一套人脸识别系统,对通讯效率的 ...

随机推荐

  1. Java如何执行操作系统的CMD命令行

    在模拟cmd调用Python时遇到一些情况,这类问题可以归类为"超时,阻塞"等,问题原因: Process p=Runtime.getRuntime().exec(String[] ...

  2. 通过Maven发部项目的最实用配置

    一.问题 我们平时开发项目,使用Maven或者Idea部署,尽可能是要做到自动化.一般情况下,做成自动化的方式有多种,下面简述我比较常用的3种. 二.解决方案一: (1)配置发部:使用IDEA自带的A ...

  3. 机甲大师S1机器人编程学习,Windows 10 安装Scratch和简单实例学习

    机甲大师S1支持 Scratch 3.0以上版本. Scratch官方网址:https://scratch.mit.edu/  最新版本为3.4.0 今天在Windows 10上,安装最新版本. 1. ...

  4. os.path.join()函数的用法

    转:https://blog.csdn.net/hduxiejun/article/details/80289476   os.path.join()函数:连接两个或更多的路径名组件 1.如果各组件名 ...

  5. Object-C学习之NSSet和NSMutableSet

    转自:http://blog.csdn.net/likandmydeer/article/details/7939749 一.简介 集合(set)是一组单值对象,它可以是固定的(NSSet).也可以是 ...

  6. i春秋——“百度杯”CTF比赛 九月场——Test(海洋cms / seacms 任意代码执行漏洞)

    打开发现是海洋cms,那就搜索相关漏洞 找到一篇介绍海洋cms的命令执行漏洞的文章:https://www.jianshu.com/p/ebf156afda49 直接利用其中给出的poc /searc ...

  7. 实验吧——你真的会PHP吗?(intval范围 php中\00的利用)

    题目地址:http://ctf5.shiyanbar.com/web/PHP/index.php 抓包在header中发现提示 访问得到源码 <?php $info = "" ...

  8. 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 ...

  9. Solr搜索器的特性及相关操作

    一.搜索处理器简介 所有的请求处理器都实现一个Java类,本例实现了solr.SearchHandler.在运行时,solr.SearchHandler被解析为内置的Solr类org.apache.s ...

  10. Vue组件间通信6种方式

    摘要: 总有一款合适的通信方式. 作者:浪里行舟 Fundebug经授权转载,版权归原作者所有. 前言 组件是 vue.js 最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的 ...