新版onenet云平台数据流对接,包括设备端MQTT和应用端API

1.资料

基本流程:

1.在云平台创建产品和设备;

2.设备通过MQTT连接,改变数据值,获取应用下发的命令;

3.应用端直接通过API下发命令,获取数据;

API调试:https://open.iot.10086.cn/console/monitor/apiDebug

文档中心:https://iot.10086.cn/doc/aiot/fuse/

2.新建产品

3.新建设备

4.设备端连接

4.1.时间戳转换

1.百度搜索时间戳转换

2.输入到期时间

4.2.token计算

4.2.1.下载官方工具

https://iot.10086.cn/doc/aiot/fuse/detail/1487

4.2.2.计算时间戳

4.2.3.生成token,填入密码

4.3.连接MQTT

4.4.订阅和发布

4.4.1.找到发布订阅格式

4.4.2.替换数据

{device-name}用设备名称替换

{cmdId}是应用端下发时带的,这里订阅的时候写#或者+就行,发布的时候从收到的消息里面获取

4.5.网页查看数据

5.应用端

5.1.id和Accesskey获取

id获取方法:头像 ----> 账号中心 ---> 个人信息 ---> 导出 ---> 查看DMP用户ID的值

Accesskey获取方法:头像 ---> 访问权限 ---> AccessKey ---> 查看

5.2.token计算代码

token计算代码,替换 resourceNameaccessKey 的值即可

java 复制代码
package com.chen.onenetapp;

import android.os.Build;

import androidx.annotation.RequiresApi;

import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.util.Base64;

import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;

public class OnenetToken {
    @RequiresApi(api = Build.VERSION_CODES.O)
    public static String assembleToken(String version, String resourceName, String expirationTime, String signatureMethod, String accessKey)
            throws UnsupportedEncodingException, NoSuchAlgorithmException, InvalidKeyException {
        StringBuilder sb = new StringBuilder();
        String res = URLEncoder.encode(resourceName, "UTF-8");
        String sig = URLEncoder.encode(generatorSignature(version, resourceName, expirationTime, accessKey, signatureMethod), "UTF-8");
        sb.append("version=")
                .append(version)
                .append("&res=")
                .append(res)
                .append("&et=")
                .append(expirationTime)
                .append("&method=")
                .append(signatureMethod)
                .append("&sign=")
                .append(sig);
        return sb.toString();
    }

    @RequiresApi(api = Build.VERSION_CODES.O)
    public static String generatorSignature(String version, String resourceName, String expirationTime, String accessKey, String signatureMethod)
            throws NoSuchAlgorithmException, InvalidKeyException {
        String encryptText = expirationTime + "\n" + signatureMethod + "\n" + resourceName + "\n" + version;
        String signature;
        byte[] bytes = HmacEncrypt(encryptText, accessKey, signatureMethod);
        signature = Base64.getEncoder().encodeToString(bytes);
        return signature;
    }

    @RequiresApi(api = Build.VERSION_CODES.O)
    public static byte[] HmacEncrypt(String data, String key, String signatureMethod)
            throws NoSuchAlgorithmException, InvalidKeyException {
        //根据给定的字节数组构造一个密钥,第二参数指定一个密钥算法的名称
        SecretKeySpec signinKey = null;
        signinKey = new SecretKeySpec(Base64.getDecoder().decode(key),
                "Hmac" + signatureMethod.toUpperCase());

        //生成一个指定 Mac 算法 的 Mac 对象
        Mac mac = null;
        mac = Mac.getInstance("Hmac" + signatureMethod.toUpperCase());

        //用给定密钥初始化 Mac 对象
        mac.init(signinKey);

        //完成 Mac 操作
        return mac.doFinal(data.getBytes());
    }

    public enum SignatureMethod {
        SHA1, MD5, SHA256;
    }

    @RequiresApi(api = Build.VERSION_CODES.O)
    public static String token() throws UnsupportedEncodingException, NoSuchAlgorithmException, InvalidKeyException {
        String version = "2020-05-29";
        String resourceName = "userid/DMP用户ID";//这里写你的用户id
        String expirationTime = System.currentTimeMillis() / 1000 + 100 * 24 * 60 * 60 + "";
        String signatureMethod = SignatureMethod.SHA1.name().toLowerCase();
        //这个也是换成自己的Accesskey
        String accessKey = "AccessKey";//这里放你的AccessKey(在Onenet官网的账户信息里面)
        String token = assembleToken(version, resourceName, expirationTime, signatureMethod, accessKey);
        System.out.println("Authorization:" + token);
        return token;
    }
}

5.3.查询数据点

API调试:https://open.iot.10086.cn/console/monitor/apiDebug

在api调试中填这3个即可,这里能调通,参照API文档写代码就没问题

5.4.命令下发

在api调试中填这4个即可,这里能调通,参照API文档写代码就没问题

相关推荐
金融RPA机器人丨实在智能5 小时前
Android Studio开发App项目进入AI深水区:实在智能Agent引领无代码交互革命
android·人工智能·ai·android studio
科技块儿5 小时前
利用IP查询在智慧城市交通信号系统中的应用探索
android·tcp/ip·智慧城市
独行soc5 小时前
2026年渗透测试面试题总结-18(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
飞睿科技5 小时前
乐鑫智能开关方案解析:基于ESP32-C系列的低功耗、高集成设计
嵌入式硬件·物联网·esp32·智能家居·乐鑫科技
王码码20356 小时前
Flutter for OpenHarmony 实战之基础组件:第二十七篇 BottomSheet — 动态底部弹窗与底部栏菜单
android·flutter·harmonyos
2501_915106326 小时前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview
ESBK20256 小时前
第四届移动互联网、云计算与信息安全国际会议(MICCIS 2026)二轮征稿启动,诚邀全球学者共赴学术盛宴
大数据·网络·物联网·网络安全·云计算·密码学·信息与通信
vistaup6 小时前
OKHTTP 默认构建包含 android 4.4 的TLS 1.2 以及设备时间不对兼容
android·okhttp
常利兵6 小时前
ButterKnife在Android 35 + Gradle 8.+环境下的适配困境与现代化迁移指南
android
撩得Android一次心动6 小时前
Android LiveData 全面解析:使用Java构建响应式UI【源码篇】
android·java·android jetpack·livedata