websocket基础使用学习

websocket基础使用学习

一、websocket是什么?

以前,很多网站为了实现推送技术,所用的技术都是Ajax 轮询。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。这种传统的模式带来很明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP请求可能包含较长的头部,其中真正有效的数据可能只是很小的一部分,显然这样会浪费很多的带宽等资源

WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在 WebSocket API 中,浏览器和服务器只需要完成一次握手,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。即实现客服实时消息回复平台主动通知之类的功能。

二、使用步骤

1.websocket服务的安装与启动

安装服务

这里用全新的项目与文件来做demo。

新建一个空文件夹,在文件夹中运行cmd,进行npm初始化命令:npm init -y

安装服务依赖包:npm install nodejs-websocket --save

编辑服务js文件:server.js

js 复制代码
    const ws = require('nodejs-websocket');
  	const POST = 8080;

  	const server = ws.createServer(connect => {
	    connect.on("text", data => {
	      console.log("received: "+data);
	      connect.sendText(data);
	    });

	    connect.on("close", (code, reason) => {
	      console.log("connection closed!");
	    });

	    connect.on('error', ()=>{
	      console.log("connection error!");
	    });
  	});

	server.listen(POST, ()=>{
		console.log("websocket server start success!");
	});

在文件夹的cmd中启动服务:node server.js,会看到下面结果:

服务就启动好了。

连接与发消息

编写html文件,来进行连接与发消息,例如:test.html

html 复制代码
<!DOCTYPE HTML>
<html>
   <head>
   <meta charset="utf-8">
   <title>测试WebSocket</title>
    
      <script type="text/javascript">
         // 打开一个 web socket
         var ws = new WebSocket("ws://127.0.0.1:8080");
            
         ws.onopen = function()
         {
            // Web Socket 已连接上,使用 send() 方法发送数据
            ws.send("发送数据");
         };
            
         ws.onmessage = function (evt) 
         { 
            var received_msg = evt.data;
         };
            
         ws.onclose = function()
         { 
            // 关闭 websocket
         };
         var i =1;
         function sendmsg(){
            ws.send("发送数据"+i++);
         }
      </script>
        
   </head>
   <body>
   
      <div id="sse">
		   <a href="javascript:sendmsg()">发消息</a>
      </div>
      
   </body>
</html>

测试结果:

总结

这里就是基础使用了。

相关推荐
Xudde.7 小时前
班级作业笔记报告0x04
笔记·学习·安全·web安全·php
晓晓hh7 小时前
JavaSE学习——迭代器
java·开发语言·学习
421!8 小时前
GPIO工作原理以及核心
开发语言·单片机·嵌入式硬件·学习
AI成长日志9 小时前
【笔面试算法学习专栏】双指针专题·简单难度两题精讲:167.两数之和II、283.移动零
学习·算法·面试
小手指动起来10 小时前
保姆级提示词工程学习总结(含实操示例+工具推荐)
人工智能·学习·自然语言处理
绛橘色的日落(。・∀・)ノ10 小时前
Matplotlib实践学习笔记
笔记·学习
chase。10 小时前
【学习笔记】AGILE:把人形机器人强化学习从“玄学”变成“工程学”
笔记·学习·敏捷流程
bu_shuo10 小时前
git练习学习网站【中文网站】
git·学习
EnglishJun11 小时前
ARM嵌入式学习(十四)--- IMX6ULL的I2C通信实现
arm开发·学习
_李小白11 小时前
【OSG学习笔记】Day 31: 渲染到纹理(RTT)
笔记·数码相机·学习