71-STM32+ESP8266+AIR202基本控制篇-移植使用-移植微信小程序MQTT底层包到自己的工程项目

<p><iframe name="ifd" src="https://mnifdv.cn/resource/cnblogs/ESA2GJK1DH1K_A/" frameborder="0" scrolling="auto" width="100%" height="1500"></iframe></p>

 

 

说明

如果代码只是给别人乐呵一下,而不能移植使用,代码便失去了它最伟大的意义.

为便于客户移植使用微信小程序连接MQTT实现通信控制,

这节说明下MQTT底层包的移植与使用

 

新建一个微信小程序工程

 

 

 

 

 

拷贝以下三个文件到新工程的utils文件夹

 

 

 

 

 

paho-mqtt.js是最底层的包

mqtt.js是我再次封装的包

public.js存放一些公共的函数

 

连接MQTT

1.根据自己的MQTT服务器更改以下信息

 

 

 

 

2.在软件启动的地方调用一次连接函数

注:只要写上连接,内部自动断线重连

var MQTT = require("./utils/mqtt.js");

MQTT.ConnectMqtt();//链接MQTT

 

 

 

 

3.编译下工程,成功连接MQTT,打印如下

 

 

 

 

4.测试断线重连

 

 

 

订阅一个主题

MQTT.subscribeTopic(
"1111", //订阅1111
0,//消息等级
function () {
console.log("订阅成功");
}, function () {
console.log("订阅失败");
}
);//订阅主题

 

建议

var MQTT = require("../../utils/mqtt.js");
var TimeNumber;//循环订阅设备主题定时器

    //订阅设备发布的主题
    try { clearInterval(TimeNumber); } catch (e) { }
    TimeNumber = setInterval(function()
    {

      MQTT.subscribeTopic(
        "1111", //订阅1111
        0,//消息等级
        function () {
          console.log("订阅成功");
          clearInterval(TimeNumber);//订阅成功清除定时
        }, function () {
          console.log("订阅失败");
        }
      );//订阅主题

    }, 1000, "null");//启动定时器,循环订阅主题,直至订阅成功

 

 

 

 

订阅多个主题

1.本身底层包不支持一次性订阅多个主题,我修改了底层包

 

 

 

2.使用

 

 

 

var TopicMultiple = ["1111", "2222"];//订阅的主题
var QosMultiple = [0, 0];//各个主题消息等级

MQTT.subscribeTopicMultiple(
        TopicMultiple,
        QosMultiple,
        function () {
          console.log("订阅成功");
        },
        function () {
          console.log("订阅失败");
        });

 

 

 

取消订阅的主题

MQTT.unSubscribeTopic(
      "1111", //取消订阅的主题
      function()
      { 
        console.log("取消订阅成功"); 
      }
    );

 

 

 

发布消息

1.发布字符串消息

MQTT.publishTopic(
      "222", //发布的主题
      "message", //发布的消息
      0, //消息等级
      false, //不需要服务器保留
      function()//发送成功回调
      {
        console.log("发送消息成功");
      }
    );

 

2.发布16进制消息

0xAA 0x88 0xFF 0xdd

MQTT.publishStringToHex(
      "222", //发布的主题
      "AA 88 FF dd", //发布的消息
      0, //消息等级
      false, //不需要服务器保留
      function ()//发送成功回调
      {
        console.log("发送消息成功");
      }
    );

 

接收消息

MQTT.SetonMessageArrivedCallBack(
      function (arg)
      {
        console.log(arg.destinationName + "    " + arg.payloadString); 
      }
    );//注册接收消息回调函数

 

 

注意:如果接收的数据有16进制,有字符串,需要加入try

MQTT.SetonMessageArrivedCallBack(
      function (arg) {
        try{
          console.log(arg.destinationName + "    " + arg.payloadString);//处理字符串消息
        }catch(e){
          console.log(e);
        }

        try {
          console.log(arg.payloadBytes);//处理16进制消息
          let byt = arg.payloadBytes;
        } catch (e) {
          console.log(e);
        }

      }
    );//注册接收消息回调函数

 

 

监听MQTT连接状态

1.监听掉线

MQTT.SetonConnectionLostCallBack(function(arg){
      console.log(arg);//打印链接失败详细信息
    });//软件掉线

 

2.监听上线

MQTT.SetonConnectionSuccessCallBack(function(){
      console.log("连接上MQTT");
    });//连接上MQTT

 

补充

封装的订阅多个主题函数也支持订阅一个主题

直接用 paho-mqtt.js,订阅的主题 1111 消息等级 0

client.subscribeMultiple(
"1111"
,
{ 
qos: 0
,
invocationContext: 
{ 
arg: null 
}, 
onSuccess: function()
{
console.log("订阅成功");
},
onFailure: function()
{
console.log("订阅失败");
} 
}
);

 

用 mqtt.js

MQTT.subscribeTopicMultiple("1111", 0, this.SubscribeTopicSuccess, this.SubscribeTopicFailure);

 

posted on 2020-08-23 20:19  广源时代  阅读(353)  评论(0编辑  收藏  举报

导航

支付宝 QQ群