基础使用
心跳机制
1、心跳机制是每隔一段时间会向服务器发送一个数据包:
告诉服务器(后台)自己还活着,同时客户端(浏览器)会确认服务器端是否还活着
2、如果还活着的话,就会回传一个数据包给客户端
3、服务端断开连接了。客户端需要重连~
实现:
- 初始化建立websocket连接,websocket监听事件
init(row) {
this.connectSocket() // 建立websocket连接
this.socket.onopen = (e) => {
console.log('Connection to server opened');
// 连接成功执行的逻辑
}
// websocket连接接收消息后监听事件
this.socket.onmessage = async(msg) => {
try {
var data = JSON.parse(msg.data)
console.log(data)
} catch(err){
return
}
// websocket连接接收消息处理逻辑
}
},
// 连接websocket
connectSocket() {
var address = window.location.hostname
var protocol = 'ws'
if (location.protocol === 'https:') {
protocol = 'wss'
}
var url = ''
url = protocol+'://'+location.host+`proxy代理字段`+'/websocket/'+`后台所需参数`
this.socket = this.createWebSocket(url)
// 监听连接失败
this.socket.onerror = this.websocketonerror
// 监听连接关闭
this.socket.onclose = this.websocketclose
},
websocketonerror () { // 监听连接失败
console.log('websocket连接断开')
this.connectSocket()
},
websocketclose (e) { // 监听连接
console.log('断开连接', e)
this.connectSocket() // websocket关闭链接重连
},
// 创建websocket对象
createWebSocket(url) {
console.log(url)
try{
if(window.WebSocket)
return new WebSocket(url);
if(window.MozWebSocket)
return new MozWebSocket(url);
} catch(e) {
}
return false;
},
- 心跳监测
1、什么时候进行心跳监测
2、逻辑代码
3、什么时候重置心跳监测
4、关闭心跳监测
websocket连接成功进行监测心跳
init(row) {
this.connectSocket()
this.socket.onopen = (e) => {
console.log('Connection to server opened');
++ this.longstart(); // 成功建立连接后,创建心跳检测
// 连接成功执行的逻辑
}
this.socket.onmessage = async(msg) => {
try {
var data = JSON.parse(msg.data)
console.log(data)
} catch(err){
return
}
// websocket连接接收消息处理
}
},
接收消息后进行心跳重置
init(row) {
this.connectSocket()
this.socket.onopen = (e) => {
console.log('Connection to server opened');
this.longstart(); // 成功建立连接后,创建心跳检测
// 连接成功执行的逻辑
}
this.socket.onmessage = async(msg) => {
++ console.log('心跳重置')
++ this.longstart();
try {
var data = JSON.parse(msg.data)
console.log(data)
} catch(err){
return
}
// websocket连接接收消息处理
}
},
逻辑代码-所需数据
data(){
return {
timeoutObj:undefined,
serverTimeoutObj:undefined,
socket:undefined
}
}
longstart() {
//1、通过关闭定时器和倒计时进行重置心跳
clearInterval(this.timeoutObj)
clearTimeout(this.serverTimeoutObj);
// 2、每隔30s向后端发送一条商议好的数据
this.timeoutObj = setInterval(()=>{
console.log('重置监测心跳')
let data={ // 与后端商量好心跳要传递的值
content: "pong",
contentType: "hert"
}
this.socket.send(JSON.stringify(data))
// 3、发送数据 2s后没有接收到返回的数据进行关闭websocket重连
this.serverTimeoutObj = setTimeout(()=>{
console.log("后台挂掉,没有心跳了....");
console.log("打印websocket的地址:"+this.socket);
this.socket.close();
}, 2000);
},30000)
},
关闭心跳机制
destroyed () {
// 1、组件销毁时,关闭与服务器的连接
if (this.socket) {
this.socket.close() // 离开路由之后断开websocket连接
}
// 2、通过关闭计时器和倒计时关闭心跳监测
clearInterval(this.timeoutObj)
clearTimeout(this.serverTimeoutObj);
},
注意事项
1、 由于我们的websocket连接关闭立即进行重连了,组件销毁时,
断开websocket连接又走了重连机制
2、 websocketclose (e) { // 关闭
this.connectSocket()
},
3、 所以我们需要定义一个变量控制是组件销毁关闭的websocket
还是心跳监测重连时关闭的websocket
定义变量判断是组件销毁关闭的websocket,还是心跳监测重连时关闭的websocket
data(){
return{
~~~~
++ lockReconnect:false // 为true时,是心跳重连的websocket断开连接
}
},
destroyed () {
this.lockReconnect=false
// 组件销毁时,关闭与服务器的连接
if (this.socket) {
this.socket.close() // 离开路由之后断开websocket连接
}
clearInterval(this.timeoutObj)
clearTimeout(this.serverTimeoutObj);
},
longstart() {
clearInterval(this.timeoutObj)
clearTimeout(this.serverTimeoutObj);
// clearInterval(this.overTime)
this.timeoutObj = setInterval(()=>{
console.log('重置监测心跳')
let data={
chatType:"hert",
receiverId: this.chatroomList.userId,
receiverName: this.chatroomList.userName,
senderAvatar: this.userInfo.avatar,
senderName: this.userInfo.userName,
content: "pong",
contentType: "hert"
}
this.socket.send(JSON.stringify(data))
this.serverTimeoutObj = setTimeout(()=>{
++ this.lockReconnect=true // 心跳重连设置为true
console.log("后台挂掉,没有心跳了....");
console.log("打印websocket的地址:"+this.socket);
this.socket.close();
// createWebSocket();
}, 2000);
},30000)
// },110000)
},
websocketclose (e) { // 关闭
console.log('断开连接', e)
//lockReconnect为true在进行重连
++ if(this.lockReconnect){
++ this.connectSocket()
++ }else{
++ }
},