简说websocket

一,什么是websocket?

  1. websocket是一种协议,它的最大特点就是,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真正的双向平等对话,属于服务器推送技术的一种。
有人会问:我们已经有了 HTTP 协议,
为什么还需要另一个协议?它能带来什么好处?

答案很简单,因为 HTTP 协议有一个缺陷:通信只能由客户端发起。

举例来说,我们想了解今天的天气,只能是客户端向服务器发出请求,
服务器返回查询结果。HTTP 协议做不到服务器主动向客户端推送信息。
复制代码

  1. WebSocket 协议在2008年诞生,2011年成为国际标准。所有浏览器都已经支持了。
  2. websocket特点
(1)建立在 TCP 协议之上,服务器端的实现比较容易。
(2)与 HTTP 协议有着良好的兼容性。默认端口也是80和443,
    并且握手阶段采用 HTTP 协议,因此握手时不容易屏蔽,
    能通过各种 HTTP 代理服务器。
(3)数据格式比较轻量,性能开销小,通信高效。
(4)可以发送文本,也可以发送二进制数据。
(5)没有同源限制,客户端可以与任意服务器通信。
(6)协议标识符是ws(如果加密,则为wss),服务器网址就是 URL。
    (如:ws://example.com:80/some/path)
复制代码

二,websocket用来干什么?

  1. 支持双向通信,实时性更强(你可以来做个QQ,微信了);
  2. 较少的控制开销(连接创建后,ws客户端、服务端进行数据交换时,协议控制的数据包头部较少)

三,简要实现一个websocket

  • html页面
// 创建一个index.html文件
// 下面直接写WebSocket

// 只需要new一下就可以创建一个websocket的实例
// 我们要去连接ws协议

// 这里对应的端口就是服务端设置的端口号9999
let ws = new WebSocket('ws://localhost:9999');

// onopen是客户端与服务端建立连接后触发
ws.onopen = function() {
    ws.send('收到服务端消息了,开心');
};

// onmessage是当服务端给客户端发来消息的时候触发
ws.onmessage = function(res) {
    console.log(res);   // 打印的是MessageEvent对象
    // 真正的消息数据是 res.data
    console.log(res.data);
};

复制代码
  • 下面开始撸node.js这个server.js服务文件吧
// 后台需要安装ws包
// npm i ws -S

const express = require('express');
const app = express();

// 设置静态文件夹
app.use(express.static(__dirname));
// 监听3000端口
app.listen(3000);

// 开始创建一个websocket服务
const Server = require('ws').Server;
// 这里是设置服务器的端口号,和上面的3000端口不用一致
const ws = new Server({ port: 9999 });

// 监听服务端和客户端的连接情况
ws.on('connection', function(socket) {
    // 监听客户端发来的消息
    socket.on('message', function(msg) {
        console.log(msg);   // 这个就是客户端发来的消息
        // 来而不往非礼也,服务端也可以发消息给客户端
        socket.send(`这里是服务端对你说的话: ${msg}`);
    });
});
复制代码

copy了一遍,还是挺简单的。

接下来还没完,由于websocket是H5标准出的东西,老版本的浏览器当然就不能很好的支持了,这时前端就要处理该死的兼容问题了

正因如此,世上才会有了另外一个更好用的库出现,这就是大名鼎鼎的socket.io,有兴趣的可以去了解一下。

参考文章:

转载于:https://juejin.im/post/5cd78a776fb9a032447f1682

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值