最近在研究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鏈接密碼