链接:https://www.zhihu.com/question/20215561/answer/157908509
来源:知乎
作者:腾讯云技术社区
以下简要介绍一下WebSocket的原理及运行机制。
WebSocket是HTML5下一种新的协议。它实现了浏览器与服务器全双工通信,能更好的节省服务器资源和带宽并达到实时通讯的目的。它与HTTP一样通过已建立的TCP连接来传输数据,但是它和HTTP最大不同是:
传统HTTP客户端与服务器请求响应模式如下图所示:

WebSocket模式客户端与服务器请求响应模式如下图:

上图对比可以看出,相对于传统HTTP每次请求-应答都需要客户端与服务端建立连接的模式,WebSocket是类似Socket的TCP长连接通讯模式。一旦WebSocket连接建立后,后续数据都以帧序列的形式传输。在客户端断开WebSocket连接或Server端中断连接前,不需要客户端和服务端重新发起连接请求。在海量并发及客户端与服务器交互负载流量大的情况下,极大的节省了网络带宽资源的消耗,有明显的性能优势,且客户端发送和接受消息是在同一个持久连接上发起,实时性优势明显。
相比HTTP长连接,WebSocket有以下特点:
<template>
<div id="app">
<router-view />
</div>
</template>
<script>
export default {
created() {
this.initWebSocket();
},
methods: {
initWebSocket() {
//初始化weosocket
let url = ‘wss:wss.xxxxxxx.com:8282‘
const wsuri = url; //ws地址
this.websocket = new WebSocket(wsuri);
this.websocket.onopen = this.websocketonopen;
this.websocket.onerror = this.websocketonerror;
this.websocket.onmessage = this.websocketonmessage;
this.websocket.onclose = this.websocketclose;
},
websocketonopen() {
console.log("WebSocket连接成功");
let data = {
type: "user_init",
userid: ‘xxx‘
}
this.websocket.send(
// 发送数据
JSON.stringify(data)
);
},
websocketonerror(e) {
//错误
// this.initWebSocket()
console.log("WebSocket连接发生错误");
},
websocketonmessage(e) {
//数据接收
var that = this;
var data = JSON.parse(e.data);
this.$store.commit(‘SET_ws‘, data)
console.log("接收数据");
//操作处理...
},
websocketsend(agentData) {
//数据发送
this.websocket.send(agentData);
},
websocketclose(e) {
//关闭
console.log(JSON.stringify(e));
},
},
}
</script>
原文:https://www.cnblogs.com/jing-zhe/p/14183957.html