vue + webSocket 实时任务信息通知

boyanx5个月前技术教程19

vue + webSocket 实时任务信息通知

websocket

WebSocket 协议在2008年诞生,2011年成为国际标准。所有浏览器都已经支持了。
它的最大特点就是,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真正的双向平等对话,属于服务器推送技术的一种。

特点

建立在TCP协议之上,服务端的实现比较容易; 与HTTP协议有着良好的兼容性。默认端口也是80和443,并且握手阶段采用HTTP协议,因此握手时不容易屏蔽,能通过各种HTTP代理服务器; 数据格式比较轻量,性能开销小,通信高效; 可以发送文本,也可以发送二进制数据 没有同源限制,客户端可以与任意服务器通信 协议标识符是 WS(如果加密,则为WSS),服务器网址就是URL

image

VUE + WebSocket 长链接实现

在项目的创建 utils/websocket.js

<!--引入store,用于管理socket推送来的消息-->
import store from '../store'
<!--封装websocket对象-->
const WS = {
    $ws:null, // webscoket实例
    wsUrl: 'ws://xxxxx.com:80/xxx', // websocket链接地址
    <!--初始化webSocket-->
    createWS:function(){
        if('WebSocket' in window){
            this.$ws = new WebSocket(wsURl)
            this.$ws.onopen = this.wsOpen
            this.$ws.onmessage = this.wsMessage
            this.$ws.onerror = this.wsError
            this.$ws.onclose = this.wsClose
        } else {
            alert('当前浏览器不支持webSocket')
        }
    },
    <!--webSocket 打开-->
    wsOpen: function() {
        this.$ws.send('连接成功')
        console.log('== websocket open ==')
        <!--开始心跳-->
        heartBeat.start()
    },
    <!--websocket 接收到服务器消息-->
    wsMessage:function(msg) {
        console.log('== websocket message ==', msg)
        <!--接受到消息,重置心跳-->
        heartBeat.reset()
        store.commit('SET_WS_MSG', msg.data)
    },
    <!--websocket 发生错误-->
    wsError: function(err){
        console.log('== websocket error ==', err)
    },
    <!--websocket 关闭连接-->
    wsClose: function(event){
        console.log('== websocket close ==', event)
    }
}
<!--webSocket 心跳-->
const heartBeat = {
    timeout:30000, // 心跳重连时间
    timeoutObj:null, // 定时器
    reset:function(){
        clearInterVal(this.timeoutObj)
        console.log('websocket 心跳')
        WS.start()
    },
    start:function(){
        this.timeoutObj = setTimeout(function(){
            if(WS.$ws.readyState === 1){
                WS.$ws.send('HeartBeat')
            }
        },this.timeout)
    }
}
export default WS

在main.js中引入WS,挂载到Vue原型上

    import Vue from 'vue'
    import WS from '@/util/websocket'
    Vue.prototype.$ws = WS

在store/index.js创建全局数据存储

    const store= new Vuex.Store({
        state:{
            webSocketMsg:''
        },
        mutations:{
            SET_WS_MSG (state, msg) =>{
                state.webSocketMsg = msg
            }
        }
    })

在单个组件内部使用

    computed:{
        getWsMsg (){
            return this.$store.state.webSocketMsg
        }
    },
    watch:{
        getWsMsg:{
            handler: function(newVal) {
                console.log(newVal)
                alert('接收到webSocket推送'+ newVal)
            }
        }
    }

如果要在所有的界面都能接收socket推送消息,并弹出提示可以在布局组件(Layout.vue ...)中监听

    computed:{
        getWsMsg (){
            return this.$store.state.webSocketMsg
        }
    },
    watch:{
        getWsMsg:{
            handler: function(newVal) {
                console.log(newVal)
                alert('接收到webSocket推送'+ newVal)
            }
        }
    }

参考文档

  • WebSocket 教程
  • WebSocket加入心跳包防止自动断开连接


作者:Beppo
链接:
https://www.jianshu.com/p/fe8bd81814b0

来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关文章

前端流行框架Vue3教程:16. 组件事件配合`v-model`使用

组件事件配合v-model使用如果是用户输入,我们希望在获取数据的同时发送数据配合v-model 来使用,帮助理解组件间的通信和数据绑定。 第一步:创建子组件(SearchComponent.vue)...

Vue+Element UI实现断点续传、分片上传、秒传

作者:Pseudo 转发链接:https://segmentfault.com/a/1190000023434864凡是要知其然知其所以然文件上传相信很多朋友都有遇到过,那或许你也遇到过当上传大文件时...

ElementPlusX + RuoyiAI:Vue3 首个 AI 开发模板开源了!

在 AI 技术飞速发展的今天,开发一款自己的 AI 应用成为了许多开发者的追求。然而,从零开始搭建一个完整的 AI 开发环境,往往需要耗费大量的时间和精力。为了帮助开发者快速进入 AI 开发领域,一个...

Vue进阶(幺伍肆):vue-resource(vue-resource.js)

前言vue-resource是Vue.js的一款插件,它可以通过XMLHttpRequest或JSONP发起请求并处理响应。也就是说,$.ajax能做的事情,vue-resource插件一样也能做到,...

SpringBoot + Vue (四)文件上传 + 拦截器

将一张test.jpg的图片放到Static包下,然后在浏览器中输入localhost:8080/test.jpg 就可以看到这种图片了注意:如果这个时候浏览器无法显示图片,先要清除一下Maven的P...

Vue小知识:如何在前端处理上传文件

转载说明:原创不易,未经授权,谢绝任何形式的转载在开发前端应用程序时,有时我们可能需要允许用户上传图像文件。稍后,我们可以处理图像文件,并在必要时将其发送到后端进行进一步处理和存储。最常见的图像文件格...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。