vue-cli3使用mqtt

前言:因公司業(yè)務(wù)权旷,最近在做一個(gè)物聯(lián)網(wǎng)平臺(tái)的后臺(tái)管理系統(tǒng)。采用的技術(shù)是vue-cli3躲查,elementUI。因?yàn)橛行枨髮?duì)設(shè)備數(shù)據(jù)進(jìn)行實(shí)時(shí)監(jiān)控姐霍,故前端需要使用mqtt來(lái)接收實(shí)時(shí)數(shù)據(jù)典唇。將個(gè)人踩坑整理出來(lái)蚓聘,希望對(duì)大家有幫助。


MQTT是什么

MQTT是機(jī)器對(duì)機(jī)器(M2M)/物聯(lián)網(wǎng)(IoT)連接協(xié)議与纽。它被設(shè)計(jì)為一個(gè)極其輕量級(jí)的發(fā)布/訂閱消息傳輸協(xié)議塘装。對(duì)于需要較小代碼占用空間和/或網(wǎng)絡(luò)帶寬非常寶貴的遠(yuǎn)程連接非常有用,是專為受限設(shè)備和低帶寬僚碎、高延遲或不可靠的網(wǎng)絡(luò)而設(shè)計(jì)阴幌。這些原則也使該協(xié)議成為新興的“機(jī)器到機(jī)器”(M2M)或物聯(lián)網(wǎng)(IoT)世界的連接設(shè)備矛双,以及帶寬和電池功率非常高的移動(dòng)應(yīng)用的理想選擇。例如懒闷,它已被用于通過(guò)衛(wèi)星鏈路與代理通信的傳感器栈幸、與醫(yī)療服務(wù)提供者的撥號(hào)連接,以及一系列家庭自動(dòng)化和小型設(shè)備場(chǎng)景玩焰。它也是移動(dòng)應(yīng)用的理想選擇芍锚,因?yàn)樗w積小荔棉,功耗低润樱,數(shù)據(jù)包最小壹若,并且可以有效地將信息分配給一個(gè)或多個(gè)接收器皂冰。
在我個(gè)人理解,其實(shí)就跟websocket差不多赂蕴,前端與后臺(tái)一直建立連接舶胀,后臺(tái)會(huì)持續(xù)主動(dòng)推過(guò)來(lái)數(shù)據(jù),不用我們主動(dòng)去發(fā)請(qǐng)求去請(qǐng)求數(shù)據(jù)糖赔。是一個(gè)雙向通信連接轩端。
具體大家可以看mqtt官網(wǎng)自行了解mqtt中文網(wǎng)

vue項(xiàng)目中如何使用mqtt

1.安裝mqtt

npm i mqtt --save

2.使用mqtt

這里我將mqtt配置寫(xiě)到一個(gè)單獨(dú)的js中

import mqtt from 'mqtt'
//這里配置的是一些需要的參數(shù)
const options = {
  port: 443,
  clientId: "",
  username: "",
  password: "",
  clean: true
};
//建立mqtt連接實(shí)例
const client = mqtt.connect("wss://www.xxxxxx.cn/mqtt",options);
export default client

因?yàn)樵陧?xiàng)目中 有好幾個(gè)模塊都需要這個(gè)實(shí)時(shí)數(shù)據(jù),所以此時(shí)需要在切換路由時(shí)保持?jǐn)?shù)據(jù)一直在接收奋构。如果不保存在一個(gè)公共的地方弥臼,在路由跳轉(zhuǎn)時(shí)連接就會(huì)斷開(kāi)舱呻,需要重新在新的路由頁(yè)面建立連接悠汽。所以我就將接收到的數(shù)據(jù)存到了vuex中,這樣全部的組件都可以取到實(shí)時(shí)數(shù)據(jù)茬高,將建立連接放在了app.vue下假抄。
在vuex中的stroe.js中

import client from '@/mqtt'  // 引入剛才配的mqtt

state ={
  mqttData:{}  //接收到mqtt實(shí)時(shí)數(shù)據(jù)
}
mutations = {
  SET_MQTTDATA:(state,data)=>{
    state.mqttData = data;
  }
}
actions = {
  connectMqtt({ commit }){
    client.on("connect", function() {
      console.log("mqtt連接成功")
      client.subscribe("/test/thing/data/post", function(err) {}) //這里是需要訂閱的topic
    })
    client.on("message", function(topic, message) {
      let data = JSON.parse(message)
      commit('SET_MQTTDATA',data)
      }
    })
  }
}

subscribe是監(jiān)聽(tīng)某個(gè)topic,然后可以通過(guò)on來(lái)監(jiān)聽(tīng)返回來(lái)的數(shù)據(jù)丽猬,將數(shù)據(jù)存到state中脚祟,因?yàn)閿?shù)據(jù)是實(shí)時(shí)變化的由桌,可以將data存到 getters中

getters = {
  mqtt_data:state => state.mqttData
}

在app.vue中觸發(fā)監(jiān)聽(tīng)

<template>
  <div id="app">
    <router-view />
  </div>
</template>

<script>
export default {
  name: 'App',
  mounted(){
    this.$store.dispatch('connectMqtt');
  },
}
</script>

這樣系統(tǒng)一進(jìn)來(lái)就會(huì)建立連接邮丰,實(shí)時(shí)獲取數(shù)據(jù),刷新頁(yè)面會(huì)重新觸發(fā)mouted函數(shù)剪廉,重新建立連接斗蒋。
在頁(yè)面中使用

computed:{
        mqttData(){
            return this.$store.getters.mqtt_data
        }
    },
    watch:{
       mqttData(val){
           //數(shù)據(jù)變化,進(jìn)行相應(yīng)操作
       } 
    },

因?yàn)樵趘ue中使用mqtt資料很少骤星,自己摸索著暫時(shí)完成了階段的開(kāi)發(fā)任務(wù)爆哑,應(yīng)該還有更好更優(yōu)的處理方式,希望大家多多指正队贱,一起進(jìn)步潭袱。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末屯换,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子彤悔,更是在濱河造成了極大的恐慌,老刑警劉巖抑片,帶你破解...
    沈念sama閱讀 212,383評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件敞斋,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡植捎,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)丢郊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)枫匾,“玉大人干茉,你說(shuō)我怎么就攤上這事很泊。” “怎么了委造?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,852評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵昏兆,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我爬虱,道長(zhǎng),這世上最難降的妖魔是什么死讹? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,621評(píng)論 1 284
  • 正文 為了忘掉前任赞警,我火速辦了婚禮虏两,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘碘举。我一直安慰自己搁廓,他們只是感情好耕皮,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,741評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布凌停。 她就那樣靜靜地躺著罚拟,像睡著了一般完箩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上弊知,一...
    開(kāi)封第一講書(shū)人閱讀 49,929評(píng)論 1 290
  • 那天秩彤,我揣著相機(jī)與錄音,去河邊找鬼漫雷。 笑死,一個(gè)胖子當(dāng)著我的面吹牛降盹,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播仅胞,決...
    沈念sama閱讀 39,076評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼干旧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼妹蔽!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起编整,我...
    開(kāi)封第一講書(shū)人閱讀 37,803評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤掌测,失蹤者是張志新(化名)和其女友劉穎汞斧,沒(méi)想到半個(gè)月后夜郁,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體竞端,經(jīng)...
    沈念sama閱讀 44,265評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡事富,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,582評(píng)論 2 327
  • 正文 我和宋清朗相戀三年统台,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了啡邑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饺谬。...
    茶點(diǎn)故事閱讀 38,716評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖森缠,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情列肢,我是刑警寧澤宾茂,帶...
    沈念sama閱讀 34,395評(píng)論 4 333
  • 正文 年R本政府宣布跨晴,位于F島的核電站,受9級(jí)特大地震影響怀骤,放射性物質(zhì)發(fā)生泄漏蒋伦。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,039評(píng)論 3 316
  • 文/蒙蒙 一痕届、第九天 我趴在偏房一處隱蔽的房頂上張望研叫。 院中可真熱鬧,春花似錦、人聲如沸渤昌。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,798評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)忌栅。三九已至曲稼,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瑞驱,已是汗流浹背窄坦。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,027評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工彤侍, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留逆趋,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,488評(píng)論 2 361
  • 正文 我出身青樓般哼,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親惠窄。 傳聞我的和親對(duì)象是個(gè)殘疾皇子蒸眠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,612評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容

  • 一、簡(jiǎn)述 MQTT(Message Queuing Telemetry Transport杆融,消息隊(duì)列遙測(cè)傳輸協(xié)議)...
    高廣超閱讀 24,812評(píng)論 2 5
  • 一楞卡、MQTT簡(jiǎn)介 ??MQTT(Message Queuing Telemetry Transport,消息隊(duì)列遙...
    無(wú)劍_君閱讀 283評(píng)論 0 0
  • 一、簡(jiǎn)述 MQTT(Message Queuing Telemetry Transport蒋腮,消息隊(duì)列遙測(cè)傳輸協(xié)議)...
    timothyue1閱讀 4,085評(píng)論 0 4
  • 今天是周六淘捡,是我第4次換食第4天。早上起來(lái)記錄心想生活的教導(dǎo)課程池摧。記錄完趕緊洗澡吹頭焦除,享受我昨天新買(mǎi)的飛...
    李恩億的書(shū)屋閱讀 458評(píng)論 0 2
  • 經(jīng)歷了本年度的第一戰(zhàn)。和想象中挺不一樣的作彤。原本簡(jiǎn)單的模塊這次都變得很難膘魄,其他模塊也沒(méi)有做的很好。下午的考試也有許多...
    行道與共閱讀 76評(píng)論 0 1