WebSocket连接MQTT方案之阿里云及其它平台通解

WebSocket连接MQTT方案之阿里云及其它平台通解

前言:前段时间突发奇想,做一个物联网项目。下位机通过ESP8266连接云平台(oneNET)将数据传给WEB端(VUE写的)。于是问题就发生了。。。web端能够连接EMQX的mqtt,并且成功订阅和通讯,但是就是连接不上OneNET的MQTT。于是查找了几乎网上所有现有的WEB连接mqtt的方案,没有一个成功。而此时我还是在怀疑是自己的代码问题(因为此前也做过oneNET的mqtt连接,只不过是android端的而已),按道理只是将连接时的参数改成云平台的对应的就行的。最后去看了oneNET的官方文档,发现不支持Websocket!!!(之前也看过,但好像忽略了这一点)。于是在心态接近崩溃的边缘,改用了连接阿里云的方案。。。

环境:

    1. Vue:vue3

    2. Vue-cli: 4.5.15

    3. IDE: Vs code

    4. Mqtt:4.3.7


阿里云的物联网云服务器怎么申请,创建设备这些我就不说了,一搜一大堆。只要记得拿到连接参数。

实现方案

由于我的界面有子界面,并且使用mqtt就是要实时监控设备的状态以及接收数据和下发指令。如果没切换一个页面就要去重新连接一遍,那我为什么不用HTTP呢。所以如果只是要简单的学习,可以写在需要连接的界面的生命周期函数里去实现的。如果想要解决切换重连的问题,则需要mqtt的连接实例一直存在,且外部变化,如界面刷新不能轻易的改变mqtt连接状态,而解决这个问题就可以用到Vuex去解决。vuex可用于父子界面传值,那么我在跳转界面时,在创建时则获取到连接实例,并且赋值一个新的变量,不就能监听和发送服务器给的消息了吗。

由于用的Vue3的写法,可能和2的写法有很大差别,但只要看懂了,应该还是很容易重现的。

代码实现

目录:index.js  (vuex)

// 导入

import{createStore}from'vuex'

importmqttfrom'mqtt'

// 连接参数

varoptions={

// 下面这些参数在每个平台的叫法都不一样  阿里云,设备里有个mqtt连接参数,名字就是这些

connectTimeout:4000,// 超时时间

clientId:'XXXXXXXXXX',//在oneNET中这个是产品ID

username:'XXXXXXXXX',// 在oneNET中这个是鉴权设备ID

password:'XXXXXXXXX',//在oneNET中这个是鉴权

cleanSession:false,// 保留信息

keepAlive:60// 心跳值

}

// 要订阅的主题   每个平台的规则也不一样,一般来说只要订阅同一个主题就可以了,主题名字都可以随意的。

varsubscription={

topic:'XXXXXX',// 主题名字

// 通讯质量,有0,1,2。

//0是至多发一次,如果要接收的客服端不在线,则消息可能丢失

//1是至少发一次,如果对方没接到,会重发,但无法保障消息重复

//2是对1的限制,会重发,但是会保障消息到达对方并且只会到达一次

qos:0

}

//VueX

exportdefaultcreateStore({

state:{

client:null,//连接

recvData:""//接收消息

   },

mutations:{//可以写入方法(非异步)

//连接mqtt

MqttClient(state){

try{

//创建连接对象   其中 xxxx 为IP地址或者域名(阿里云用的是域名),xx为端口号,options为连接参数(上面已经定义)

state.client=mqtt.connet("ws://xxxx:xx",options)

}catch(error){

console.log("mqtt连接失败",error)

           }

//连接成功以后,订阅主题

state.client.on("connect",(error)=>{

console.log("连接成功")

    const{topic,qos}=subscription//获取上面对象里的两个值

try{

state.client.subscribe(topic,qos, (error)=>{//订阅主题

if(!error) {

console.log('订阅成功')

}else{

console.log('订阅失败')

                        }

  })

}catch(error) {

console.log('订阅错误:',error)

               }

           })

       }

   },

actions:{//可以实现异步方法

connectMqtt(context) {

      context.commit("MqttClient")//为什么要再封装呢,而不直接使用上面那个。因为连接类最好在可以使用异步调用的地方。

    }

   },

modules{}

})

至此,vuex里的代码就写完了。注意:阿里云订阅主题的是有规则的,不像其它平台可以直接用主题名就行了。去产品里,点击查看,进去以后点击Topic类列表,找到基础通信Topic,找到广播那一栏。然后根据文档正确使用。如我要订阅一个名叫“test”的主题,其它平台可能直接就输入“test”就可以订阅了,但是阿里云要按照文档规则输入  "/broadcast/XXXXXX/test"  才能正常使用,否则就算订阅了也无法直接通过订阅主题然后完成两个设备通讯。并且连接参数给的端口号为1883,但websocket不能使用这个,要使用443。而ESP8266的下位机要用1883才行。

目录:Home.vue

<template>

    <divid="main">

     ------界面我就不展示代码了--------

</div>

</template>

<scriptsetup>

import{useStore}from"vuex";

//这里直接使用了setup,这是vue3特有的,就不需要再去实现create这些了,但还是写

//export default{

//setup(){

//return {}

//}

//}

// 在script 后面申明了以后就不用写了。

conststore=useStore()//创建一个vuex的实例

//连接mqtt  这个函数原本要在最外层(父级)实现的,这个函数必须被调用一次,但不能重复调用,否则会照成多连接或者重连。

//在这里调用是因为讲解。

store.dispatch("connectMqtt");

constclient//创建一个连接变量,并赋值给他mqtt的实例连接,方便后面使用mqtt的回调

//可以看做一个监听回调,只要接到消息都会走一遍这个方法的。 其中topic为主题名字,message为接到的内容。

//如果要实现发送那些功能,可以去看下其它的博客。其实也只是调用对应的方法而已。

client.on("message",(topic,message)=>{

console.log('接到来自主题'+topic+"的信息:"+message)

   })

</script>

到此就完成了连接、订阅、接收

最后

这里我只写了连接阿里云一种,为什么标题会是通解呢。其实稍微了解过mqtt的人就会知道,其实它不过是一个协议罢了,要实现很简单的,别人已经为我们封装好了而已。我们只管实现封装好的方法就行了。而只要支持mqtt协议的平台,基本都可以通过不改变实现方法,改变连接参数就可以连接了(这里再吐槽一下oneNET,不支持websocket!!!)。我写的app当时是为了连接oneNET而写的,但只要改变IP地址、端口号、设备ID、产品ID、密码(鉴权)一样能够连接阿里云的物联网平台和EMQX。而这里用Vue3,用vuex去实现连接,其实只要看懂了方法,用vue2,在created(){}中去实现连接一样的可以的(只是刷新要重连罢了)。

注:转载请标明出处!

csdn:WebSocket连接MQTT方案之阿里云及其它平台通解_Dream's的博客-CSDN博客

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容