vue2对接mqtt

这是我做的第一个物联网项目,也是第一个项目,当时是真的很慌张,一转眼也过去这么久了,记录一下吧,是可以直接用的代码,把地址和订阅的topic换成自己需要的、变量在data里声明一下就可以了,这段代码已经跟我一起开发了pc端、app和小程序了,它已经长大了~~

// mqtt
initMqtt() {
    if (this.client != '' || this.client != null) {
        this.client == null
    }
    let that = this;
​
    // #ifdef H5
    const connectUrl = 'wss://xxxxxx:82'
    // #endif
​
    // #ifdef MP-WEIXIN||APP-PLUS
    const connectUrl = 'wxs://xxxxxx:82'
    // #endif
    // 获取终端标识
    var clientId =  `app_${Math.random().toString(16).slice(3)}`; //客户端标识
    var mqtt = require("@/utils/mqtt.min.js");
    const options = {
        clean: true, // 保留回话
        connectTimeout: 4000, // 超时时间
        // 认证信息
        clientId,
        username: 'tczpmall',
        password: 'tczpmall0607',
    }
    that.client = mqtt.connect(connectUrl, options);
    that.client.on("connect", function() {
        // console.log("连接成功....");
    });
    //如果连接错误,打印错误
    that.client.on("error", function(err) {
        console.log("err=>", err);
        that.client.end();
    });
},
// 系统消息
mqttReceive() {
    const that = this;
    let topic = `mallSysMsg/${that.user.mallUserUid}`; //要接收的主题
    that.client.subscribe(topic, function(err) {
        if (!err) {
            // console.log("subscribe success!", topic);
        } else {
            //打印错误
            console.log("err", err);
        }
    });
    that.client.on("message", function(topic, message) {
        console.log("message", message);
    });
}
  • 16
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值