onenet连接微信小程序(mqtt协议)

一、关于mqtt协议

mqtt协议常用于物联网,是一种轻量级的消息推送协议。

其中有三个角色,Publisher设备(客户端)发布主题到服务器,其他的设备通过订阅主题,获取该主题下的消息,Publisher可以发布消息到主题下,从而推送消息给其他设备。

选择MQTT协议的原因是其轻量化并且可以离线缓存消息在主题中,适合我们的移动低功耗低处理的设备。

二、使用微信小程序连接onenet

1.GET获取平台信息

javascript 复制代码
authInfo: "version=2018-10-31&res=products%2F69lP2GPJQV%2Fdevices%2Fwenshi&et=2014049634&method=md5&sign=KiQMG9fabKZC5sQtd354Bg%3D%3D",

在小程序里,借助authInfo这个变量存放授权信息,它包含了版本、资源路径、过期时间以及签名等内容。在后续发起的 HTTP 请求的请求头中,会携带此授权信息,从而实现对平台资源的访问授权。

javascript 复制代码
wx.request({
  url: "https://iot-api.heclouds.com/thingmodel/query-device-property?product_id=60KP2GPJQV&device_name=wenshi",
  header: {
    "authorization": that.data.authInfo
  },
  method: "GET",
  // 后续处理逻辑
});

小程序运用wx.request这个 API 来发送 HTTP 请求。这里是向平台的设备属性查询接口发送 GET 请求,在请求头中携带了之前提到的授权信息。平台返回的数据里包含了设备的温湿度和水位信息,成功获取后会更新到小程序的界面上。

javascript 复制代码
onLoad() {
  var that = this;
  setInterval(
    function () {
      that.getinfo();
    }, 3000
  );
}

再在循环中循环去调用getinfo去循环获取平台数据。

2.POST下发数据置平台

javascript 复制代码
openclick: function () {
  var that = this;
  wx.showToast({ title: 'xx', duration: 1000 }); // 显示提示
  
  wx.request({
    url: 'https://iot-api.heclouds.com/thingmodel/set-device-property?product_id=xxxxxx&device_name=xxxx',
    method: "POST",
    header: { "Authorization": that.data.authInfo }, // 身份认证信息
    data: {
      product_id: 'xxxxxxxx',
      device_name: 'xxxxx',
      params: { "key": true } // 控制参数:打开设备
    },
    success: function (res) {
      console.log('控制请求成功', res);
    },
    fail: function (err) {
      console.log('控制请求失败', err.errMsg);
    }
  });
},

将该函数绑定在按钮上,当按下按钮时执行一次该函数

3.echarts图形化显示

javascript 复制代码
import * as echarts from '../../ec-canvas/echarts.min';

let chart = null;

function initChart(canvas, width, height, dpr) {
    chart = echarts.init(canvas, null, {
        width: width,
        height: height,
        devicePixelRatio: dpr
    });
    canvas.setChart(chart);
    return chart;
}

相关推荐
游戏开发爱好者81 天前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
2501_915106321 天前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview
2501_915106321 天前
使用 Sniffmaster TCP 抓包和 Wireshark 网络分析
网络协议·tcp/ip·ios·小程序·uni-app·wireshark·iphone
宠友信息1 天前
2025社交+IM及时通讯社区APP仿小红书小程序
java·spring boot·小程序·uni-app·web app
“负拾捌”1 天前
python + uniapp 结合腾讯云实现实时语音识别功能(WebSocket)
python·websocket·微信小程序·uni-app·大模型·腾讯云·语音识别
换日线°2 天前
NFC标签打开微信小程序
前端·微信小程序
光影少年2 天前
AIGC + Taro / 小程序
小程序·aigc·taro
2501_915918412 天前
在 iOS 环境下查看 App 详细信息与文件目录
android·ios·小程序·https·uni-app·iphone·webview
2501_916007472 天前
没有 Mac 用户如何上架 App Store,IPA生成、证书与描述文件管理、跨平台上传
android·macos·ios·小程序·uni-app·iphone·webview
天空属于哈夫克32 天前
Go 语言实战:构建一个企微外部群“技术贴收藏夹”小程序后端
小程序·golang·企业微信