vue使用SockJS实现webSocket通信

1.在布局组件中使用

import SockJS from 'sockjs-client'
import Stomp from 'stompjs'


data() {
    return {
      stompClient: '',
      timer: ''
    }
  },
  computed: {
    fixedHeader() {
      return this.$store.state.settings.fixedHeader
    }
  },
  mounted() {
    this.initWebSocket()
  },
  beforeDestroy: function() {
    // 页面离开时断开连接,清除定时器
    this.disconnect()
    clearInterval(this.timer)
  },
  methods: {
    initWebSocket() {
      this.connection()
      const that = this
      // 断开重连机制,尝试发送消息,捕获异常发生时重连
      this.timer = setInterval(() => {
        try {
          that.stompClient.send('test')
        } catch (err) {
          console.log('断线了: ' + err)
          that.connection()
        }
      }, 5000)
    },
    connection() {
      // 建立连接对象 此次将/api/notification代理
      const socket = new SockJS('/api/notification')
      // 获取STOMP子协议的客户端对象
      this.stompClient = Stomp.over(socket)
      // 定义客户端的认证信息,按需求配置
      const headers = {
        Authorization: ''
      }
      // 向服务器发起websocket连接
      this.stompClient.connect(
        headers,
        () => {
          console.log('websocket连接成功')
          this.stompClient.subscribe(
            '/topic/server',
            (msg) => {
              // 订阅服务端提供的某个topic
              // console.log(msg.body) // msg.body存放的是服务端发送给我们的信息
            },
            headers
          )
        },
        (err) => {
          // 连接发生错误时的处理函数
          console.log('失败')
          console.log(err)
        }
      )
    },
    // 断开连接
    disconnect() {
      if (this.stompClient) {
        this.stompClient.disconnect()
      }
    }
  }

2.在vue.config.js中进行代理

在vue.config.js和.env.development和.env.production中,进行代理:

# just a flag
ENV = 'development'

# base api
VUE_APP_BASE_API = '/api/datacenter'
VUE_APP_BASE_WEBSOCKET = '/api/notification'




proxy: {
      [process.env.VUE_APP_BASE_API]: {
        target: 'http://192.168.0.139:9999',
        changeOrigin: true,
        pathRewrite: {
          ['^' + process.env.VUE_APP_BASE_API]: process.env.VUE_APP_BASE_API
        }
      },
      [process.env.VUE_APP_BASE_WEBSOCKET]: {
        target: 'http://192.168.0.139:9999',
        changeOrigin: true,
        ws: true,
        pathRewrite: {
          ['^' + process.env.VUE_APP_BASE_WEBSOCKET]: process.env.VUE_APP_BASE_WEBSOCKET
        }
      }
    }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值