OneNET 软件包使用指南

准备工作

OneNET 注册及 ENV 配置

这一部分的内容请阅读软件包中示例说明文档,完成 OneNET 平台的注册和 ENV 的配置。

OneNET port 接口移植(仅适用于开启自动注册功能)

不启用自动注册不需要移植接口,如需启用自动注册功能,请详细阅读软件包中的移植说明文档,完成移植工作。

开始使用

OneNET 初始化

在 ENV 里面已经配置好了连接云平台需要的各种信息,直接调用onenet_mqtt_init函数进行初始化即可,设备会自动连接 OneNET 平台。

推送数据

当需要上传数据时,可以按照数据类型选择对应的 API 来上传数据。代码示例如下:

  1. char str[] = { "hello world" };
  2.  
  3. /* 获得温度值 */
  4. temp = get_temperature_value();
  5. /* 将温度值上传到 temperature 数据流 */
  6. onenet_mqtt_upload_digit("temperature",temp);
  7.  
  8. /* 将hello world上传到 string 数据流 */
  9. onenet_mqtt_upload_string("string",str);

除了支持上传数字和字符串外,软件包还支持上传二进制文件。

可以通过onenet_mqtt_upload_binonenet_mqtt_upload_bin_by_path来上传二进制文件。代码示例如下

  1. uint8_t buf[] = {0x01, 0x02, 0x03};
  2.  
  3. /* 将根目录下的1.bin文件上传到 bin 数据流 */
  4. onenet_mqtt_upload_bin_by_path("bin", "/1.bin");
  5. /* 将 buf 中的数据上传到 bin 数据流 */
  6. onenet_mqtt_upload_bin(("bin", buf, 3);

命令接收

OneNET 支持下发命令,命令是用户自定义的。用户需要自己实现命令响应回调函数,然后利用onenet_set_cmd_rsp_cb将回调函数装载上。当设备收到平台下发的命令后,会调用用户实现的命令响应回调函数,等待回调函数执行完成后,将回调函数返回的响应内容再发给云平台。保存响应的内存必须是动态申请出来的,在发送完响应后,程序会自动释放申请的内存。代码示例如下:

  1. static void onenet_cmd_rsp_cb(uint8_t *recv_data, size_t recv_size,uint8_t **resp_data,
  2. size_t *resp_size)
  3. {
  4. /* 申请内存 */
  5.  
  6. /* 解析命令 */
  7.  
  8. /* 执行动作 */
  9.  
  10. /* 返回响应 */
  11.  
  12. }
  13.  
  14. int main()
  15. {
  16. /* 用户代码 */
  17.  
  18. onenet_mqtt_init();
  19.  
  20. onenet_set_cmd_rsp_cb(onenet_cmd_rsp_cb);
  21.  
  22. /* 用户代码 */
  23.  
  24. }

信息获取

数据流信息获取

用户可以通过onenet_http_get_datastream来获取数据流的信息,包括数据流 id,数据流最后更新时间,数据流单位,数据流当前值等等,获取的数据流信息会保存在传入的 datastream 结构体指针所指向的结构体中。代码示例如下

  1. struct rt_onenet_ds_info ds_temp;
  2.  
  3. /* 获取到 temperature 数据流的信息后保存到 ds_temp 结构体中 */
  4. onenet_http_get_datastream("temperature",ds_temp);

数据点信息获取

数据点信息可以通过以下 3 个 API 来获取

cJSON _onenet_get_dp_by_limit(char _ds_name, size_t limit);cJSON _onenet_get_dp_by_start_end(char _ds_name, uint32_t start, uint32_t end, size_t limit);cJSON _onenet_get_dp_by_start_duration(char _ds_name, uint32_t start, size_t duration, size_t limit);

这三个 API 返回的都是 cJSON 格式的数据点信息,区别只是查询的方法不一样,下面通过示例来讲解如何使用这 3 个 API。

  1. /* 获取 temperature 数据流的最后10个数据点信息 */
  2. dp = onenet_get_dp_by_limit("temperature",10);
  3.  
  4. /* 获取 temperature 数据流2018年7月19日14点50分0秒到2018年7月19日14点55分20秒的前10个
  5. 数据点信息 */
  6. /* 第二、三个参数是Unix时间戳 */
  7. dp = onenet_get_dp_by_start_end("temperature",1531983000153198332010);
  8.  
  9. /* 获取 temperature 数据流2018年7月19日14点50分0秒往后50秒内的前10个数据点信息 */
  10. /* 第二个参数是Unix时间戳 */
  11. dp = onenet_get_dp_by_start_end("temperature",15319830005010);

注意事项

  • 设置命令响应回调函数之前必须要先调用onenet_mqtt_init函数,在初始化函数里会将回调函数指向RT_NULL。
  • 命令响应回调函数里存放响应内容的 buffer 必须是 malloc 出来的,在发送完响应内容后,程序会将这个 buffer 释放掉。

    评论

原文: https://www.rt-thread.org/document/site/submodules/onenet/docs/user-guide/