vue中使用stompjs實現mqtt消息推送通知

最近在研究vue+webAPI進行先後端分離,在一些如前端定時循環請求後臺接口判斷狀態等應用場景用使用mqtt進行主動的消息推送可以很大程度的減少服務端接口的壓力,提升系統的效率,並且能夠利用mqtt消息通知創建一個獨立於業務服務系統的消息通知服務,這個服務還能夠與開發的語言無關,客戶端既能夠是安卓也能夠是ios,也能夠是java或者c#,python等。閒話很少扯,這裏只是實現了在vue中使用mqtt的js客戶端,後臺用.net WEB API用的是c#的mqtt客戶端前端

第一步:安裝依賴vue

npm install stompjsjava

運行npm run dev可能會報錯,提示安裝net,執行命令python

npm install --save netios

第二部:組件中應用stompjsweb

組件中的js部分npm

<script>
import Stomp from 'stompjs'
---在sysconstant.js配置文件中配置mqtt的服務端地址,帳號等信息
import { MQTT_SERVICE, MQTT_USERNAME, MQTT_PASSWORD } from '../../config/sysconstant.js'
export default {
  name: 'entry',
  data () {
    return {
      client: Stomp.client(MQTT_SERVICE)
    }
  },
  created () {
    this.connect()
  },
  methods: {
    onConnected: function (frame) {
      console.log('Connected: ' + frame)
      var topic = '/topic/AllCustomer'  
---訂閱頻道
      this.client.subscribe(topic, this.responseCallback, this.onFailed) 
    },
    onFailed: function (frame) {
      console.log('Failed: ' + frame)
    },
    responseCallback: function (frame) {
      console.log('responseCallback msg=>' + frame.body)
      ---接收消息
    },
    connect: function () {
      ---初始化mqtt客戶端,並鏈接mqtt服務
      var clientid = util.uuid()
      var headers = {
        'login': MQTT_USERNAME,
        'passcode': MQTT_PASSWORD,
        'client-id': clientid
        // additional header
      }
      this.client.connect(headers, this.onConnected, this.onFailed)
    }
  }
}
</script>

配置文件sysconstant.js
/**
 * 配置文件,記錄系統中固定的參數
 */
export const MQTT_SERVICE = 'ws://127.0.0.1:61623/stomp' // mqtt服務地址
export const MQTT_USERNAME = 'admin' // mqtt鏈接用戶名
export const MQTT_PASSWORD = 'password' // mqtt鏈接密碼
相關文章
相關標籤/搜索