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


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

第一步:安裝依賴

npm install stompjs

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

npm install --save net

第二部:組件中應用stompjs

組件中的js部分

<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連接密碼

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM