STM32学习之NB-IoT(三)——天翼物联平台AIoT注册及连接

2024-02-26 12:10

本文主要是介绍STM32学习之NB-IoT(三)——天翼物联平台AIoT注册及连接,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一. 平台配置

1.1 平台注册

        本次项目使用的是电信的NB卡,对应的平台为天翼物联(AIoT),平台链接:

https://sso.ctwing.cn/login#/https://sso.ctwing.cn/login#/        进入后先注册一个自己的账号,随后登陆。

1.2 产品注册

        登陆后等待平台加载一会儿,完成后点击右上角的控制台。

         如果想要接入自己的 NB-IoT 设备,首先需要开通“天翼物联网平台(AIoT)-通用组件服务”。在“应用向导_AEP”页面,点击“立即开通”按钮(该服务可以免费开通)。

        开通服务之后,可以在左侧导航栏的“设备管理”-> “产品”菜单里,点击右上角的“创建产品”开 始创建产品。

         填写产品的参数,大家根据自己的项目做相应修改,博主设置的参数如下:

  • 产品名称: 小熊座 NB-IoT 开发板
  • 产品分类: “智慧城市”->“环境感知”-> “温湿度监测”
  • 节点类型: 选择“设备”
  • 接入方式: 选择“设备直连”
  • 网络类型: 选择“NB-IoT”
  • 通信协议: 选择“LWM2M”(Ligh Wweight Machine to Machine)
  • 数据加密方式: 选择“明文”
  • 认证方式: 这里选择“IMEI 认证”
  • Endpoint 格式: 这里选择 “imei”
  • 是否已有电信官方认证通过的 profile: 这里选择“否”
  • 设备型号: 这里设置为 “BC28”
  • 是否透传: 这里选择“否”
  • 消息格式: 这里选择“紧凑型二进制”
  • 省电模式: 这里选择“PSM”
  • 产品描述: 基于NB-IoT的智能路灯

1.3 添加设备

        点击进入刚添加的设备(这里博主就用前边做的项目做演示了)

        先点击“设备管理”,再点击“添加设备”(大家做到这一步时下边马赛克那一行应该是空白的,此处是博主偷懒直接用了前边配置好的项目)。

        这里需要填入设备的 IMEI 号,IMEI号可以在 BC28 模块上使用 AT 命令“AT+CGSN=1”获取。 另外还可以选填设备的 IMSI 号,它可以使用 AT 命令“AT+CIMI”获取。(直接通过串口调试助手向BC28模块发送这两个AT指令即可获取)

        添加完成之后就可以看到新添加的设备了 (此时大家的设备还未激活,状态那一栏应为“未激活”状态,如何激活在后续会讲到)。

 1.4 新增属性

        这里以上报温度为例,讲解如何添加上报温湿度的服务。

       点击产品 ----> 服务定义----> 属性列表,框2中的是默认的多个属性,它们是这个模型的必选选项。

        如果我们要上报的数据类型在这里不存在,则可以点击“新增属性”按钮来添加新的属性。这里博主添加了一个“温度”属性,并配置了相应参数。

        设置属性的长度为 4 字节, 也就是说我们在上报温度时需要用 4 个字节长度表示温度值。(这里的属性标识大家可以自定义,图中是灰色的是因为博主之前定义过了,这里是修改界面)    

         配置完成后点击确定,可看到自定义功能的属性列表中出现了自己刚刚配置的属性,其中属性ID为43,这个ID在接下来会用到。

 1.5 新增服务

        有了属性之后,接下来我们要添加服务。具体方法是 点击 产品----> 服务定义----> 服务列表。在这里有一 些默认的服务,每个服务都有一个相应的服务 ID,如 1、2、9001、9002 等。现在我们要添加上报温度的 服务,则可以点击右下角的“新增服务”按钮。     

        根据自己需求配置服务参数,注意这里的服务 ID 不能重复,这里就直接与其属性 ID 保持一致。

         这里的参数列表点击“添加属性”,在“属性名称”中选择上一步加入的“温度”属性。

        参数配置完成后点击确定,完成后自定义功能的服务列表中可以看到新增的服务。

        接下来就可以使用这个服务来上报当前温度了。

二. 连接平台

        首先,通过 AT 命令配置设备上电后自动连接电信云 IoT 云平台服务。

(1) AT+NCONFIG=AUTOCONNECT,TRUE   //设置 NB-IoT 上电后自动附着网络

返回:

OK

(2) AT+NCDP=221.229.214.202,5683 //设置 IoT 平台服务器地址和端口为电信云平台

返回:

OK

(3) AT+QREGSWT=1  //设置附着网络后自动触发电信 IoT 云平台服务器连接

返回:

OK

(4) AT+NRB  //重启 NB-IoT 模块

返回:

REBOOTING

H??_x0010_

Boot: Unsigned

Security B.. Verified

Protocol A.. Verified

Apps A...... Verified

REBOOT_CAUSE_APPLICATION_AT

Neul

OK

(5) AT+CGPADDR  //查看 NB-IoT 模块后,是否能正常附着网络并获取到 IP 地址

返回:

+CGPADDR:0,21.74.168.172

OK

AT+NCDP?  //查看 IoT 云平台的配置是否正确

返回:

+NCDP:221.229.214.202,5683

OK

AT+NMSTATUS?  //查询 NB-IoT 是否成功注册上电信 IoT 云平台

返回:

+NMSTATUS:MO_DATA_ENABLED

OK

         此时还不用在开发板上编写程序,通过串口调试助手依次发送上方的AT指令。(注意:BC28波特率为9600,一定要勾选发送新行"\r\n"

  

        当开发板上的 NB-IoT 模块注册到云平台上后,我们在云平台上可以看到设备状态从“已注册”变成了“已激活”。 

三. 数据上报

        接下来使用 AT 命令测试上报当前温湿度值过程。

        在开始上报之前,我们需要了解电信云平台中的 数据报文编码格式,具体参考《中国电信物联网开放平台 2.1 接入指导手册.pdf》文档。(下图是从别的地方扒过来的)

         从上图可知,数据报文格式为:

  • 目前要做上报数据,所以CMDType 定义为0x02(表示上报报文),如果是下发的命令则为0x06;
  • DatasetID(服务 ID),从上图可以看出上报相对湿度的服务ID值为43,所以DatasetID值为002B;
  • PayloadLength是数据的长度,在服务中可以看出相对湿度属性的数据长度为 4 字节,所以该字段为 0004;
  • PayloadData是要上传的数据,就是当前温度值,假设当前温度为28℃,则该字段为0000001C。

        综上,目前使用NB-IoT上报当前温度值28℃的报文为:02002800040000001C。

        接下来在开发板上可以使用“AT+QLWULDATAEX”命令来发送这个报文数据到所连接的电信 IoT云平台上。

AT+QLWULDATAEX=9,02002B00040000001C,0x0100

  • 9:表示后面要发送的数据长度,02002B00040000001C是十六进制,长度为9个字节;
  • 0200xxxxxxxx:要上报的数据报文二进制编码;
  • 0x0100:表示 Send CON message;

        关于命令的详解请看BC28模块对应AT手册。

如下图是上报当前湿度和当前温度的命令执行情况。(发送时注意波特率9600,勾选发送新行

        发送后等待几秒,刷新平台界面,进入设备查看数据,能看到数据上报成功。

这篇关于STM32学习之NB-IoT(三)——天翼物联平台AIoT注册及连接的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/748836

相关文章

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

SpringBoot连接Redis集群教程

《SpringBoot连接Redis集群教程》:本文主要介绍SpringBoot连接Redis集群教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 依赖2. 修改配置文件3. 创建RedisClusterConfig4. 测试总结1. 依赖 <de

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

java连接opcua的常见问题及解决方法

《java连接opcua的常见问题及解决方法》本文将使用EclipseMilo作为示例库,演示如何在Java中使用匿名、用户名密码以及证书加密三种方式连接到OPCUA服务器,若需要使用其他SDK,原理... 目录一、前言二、准备工作三、匿名方式连接3.1 匿名方式简介3.2 示例代码四、用户名密码方式连接4