失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > NBIOT模组M5310接入中国移动物联网开放平台示例文档

NBIOT模组M5310接入中国移动物联网开放平台示例文档

时间:2019-06-03 18:50:27

相关推荐

NBIOT模组M5310接入中国移动物联网开放平台示例文档

版权声明:本文为转载,并非原创

M5310模组采用的是海思Hi2110芯片,在全球eSIM NB-IoT模组中的尺寸最小,仅19×18.4×2.7mm,节省布板面积达30%以上,具有工业级、低功耗、深覆盖、集成度高的特性,是中国移动在NB-IoT领域主打的一款核心产品。模组内置中国移动物联网开放平台OneNET协议,可有效提高用户的产品可靠性和稳定性,并方便用户快速接入OneNET云平台,减少开发周期,满足用户产品快速上市的需求。

M5310模组已成功应用于能源、汽车、消费电子等领域,广泛适用于无线抄表、智慧城市、智能家电、安防、智慧农业和环境监测以及其他诸多行业,能够提供最完善的数据传输服务,有效推动全行业模组成本大幅下降。目前,中移物联网基地已经开放提供测试样品,并顺利通过鹰潭NB-IoT窄带物联网开放实验室测试验证。一、OneNET平台介绍

中国移动物联网开放平台OneNET是由中国移动打造的PaaS物联网开放平台。平台能够帮助开发者轻松实现设备接入与设备连接,快速完成产品开发部署,为智能硬件、智能家居产品提供完善的物联网解决方案。本人使用OneNET平台差不多已经有一年半,最初使用它的时候是有一个大学生创新项目,做的是老人健康监护手表,由于团队当初不会开发自己的服务器,因此借助了OneNET。想要使用OneNET需有一个OneNET账号,注册一个即可,注册流程很简单,这里不多介绍。

二、NBIOT模组M5310介绍

1、M5310模组采用华为海思Hi2110芯片。

2、M5310模组内置UDP控制命令、可以连接自己的服务器。

3、M5310模组内置LWM2M控制指令、可以直接连接ONENET。

由于内置了LWM2M协议,并且以AT指令的形式来连接OneNET,因此使用起来非常方便。

三、在OneNET创建NBIOT产品并添加设备

OneNET创建产品并添加设备操作很简单,只需在页面进行创建和添加即可:

1、点击右上角的“开发者中心”

2、编辑产品信息

填写完信息后点击“确定”就完成产品的创建。

3、添加设备

点击平台的设备管理进行添加设备

设备类型:选择正式设备。

设备名称:随便命名。

IMEI:为NBIOT模组M5310的IMEI号。

Auth_Code:可不填写。

IMSI:为NBIOT物联SIM卡的IMSI号。

IMEI和IMSI和分别向模组发送AT+CGSN=1和AT+CIMI命令得到。

填写完毕后,选择“自动订阅”再点击“确定”就完成设备的添加。

四、M5310模组连接OneNET

1、配置串口调试助手,波特率为9600

2、上电初始化M5310

M5310

OK//开机启动信息

AT//开机之后循环发送 AT 直到返回 OK,证明模块初始化正常

OK

AT+COPS=1,2,"46000"//设置手动注册移动运营商 MNC

OK

AT+NEARFCN=0,3555//锁定频点为 3555,锁频可以有效减小搜网时间,但是频点设置错误会导致搜网失败,建议通常情况下不要设置锁频

OK

AT+CSCON=1//打开信号提示自动上报

OK

AT+CEREG=1//打开注册信息自动上报

OK

3、生成模组侧设备注册码

模组侧设备创建使用 AT+MIPLCONF 指令,其使用格式为:

AT+MIPLCONF=,,,

其中,

指示部分总数据长度,按照ASCII计数;

具体的设备配置数据,满足配置结构体规范;

配置数据分片参数;

配置数据流结束符。

这里介绍两种生成注册码的方法:

(1)使用OneNET平台的专用配置工具OneNET_config_v1.2.exe进行注册码生成:

A.用DOS命令串口打开OneNET_config_v1.2.exe工具并按如下格式填写数据:

按回车键生成对应的数据:

其中,各参数具体含义如下:

: -b Bootstrap 模式设置,1 为打开,0 为关闭; 需要 设置为 1 ;

: -e 加密模式设置,1 为打开,0 为关闭;目前不支持加密模式;

:-d Debug 等级设置:

0关闭 debug 模式

1仅打印接收/发送包数据长度

2打印发送数据包长度和接收数据内容及数据长度

3打印接收/发送数据内容及数据长度

: -ihost 设置,格式为”ServerURI:Port”;

ServerURI 远端服务器地址, 重庆平台使用 183.230.40.39

Port 远端服务器端口号, 重庆平台使用 5683

:-n 鉴权参数,格式为”IMEI;IMSI”, 对应平台侧设备 注册 时的鉴

权参数 IMEI 和 和 IMSI;

:-p 本端端口号,范围 0~65535;缺省值 0,当选择缺省时,模组

会自动从 32768~65535 中选择一个可用的端口号;

<</span>time>:-t设备存活时间,标示终端和 OneNET 平台之间连接的存活周

期,设置范围为 10s~86400s;

:-u 设置 PUT 和 POST 指令分片长度,范围 0~6,指示分片长度

为 2^(4+u),缺省值为 5;

:-g 设置GET指令分片长度,范围0~6,指示分片长度为2^(4+g),

缺省值为 5;

: -x 设置触发分片操作的最大长度,范围 0~2,指示阈值为

2^(4+x),缺省值为 2。

如 无 特殊 需求,建议分片参数 block1 和 和 block2设置 为缺省值,block2th设

置为 为 1 。

这种方法适用于采用串口调试助手调试M5310模组。

(2)使用相关算法生成注册码:

#include "memory.h"

#include "string.h"

#include "stdio.h"

#include "stdlib.h"

#include "string.h"

typedef enum

{

MIPL_DEBUG_LEVEL_NONE = 0,

MIPL_DEBUG_LEVEL_RXL,

MIPL_DEBUG_LEVEL_RXL_RXD,

MIPL_DEBUG_LEVEL_TXL_TXD,

} MIPL_DEBUG_LEVEL_E;

typedef unsigned char uint8;

typedef unsigned short uint16;

typedef unsigned uint32;

#define MIPL_BOOT1

#define MIPL_ENCRYPT0

#define MIPL_DEBUGMIPL_DEBUG_LEVEL_NONE

#define MIPL_PORT0

#define MIPL_KEEP_ALIVE3000

#define MIPL_BLOCK15

#define MIPL_BLOCK25

#define MIPL_BLOCK2TH1

#define MIPL_URI"coap:\/\/183.230.40.39:5683"

#define MIPL_ENDPOINT"86102915220;460040236709122"

typedef struct

{

uint8 boot;

uint8 encrypt;

MIPL_DEBUG_LEVEL_E debug;

uint16 port;

uint32 keep_alive;

size_t uri_len;

char* uri;

size_t ep_len;

char* ep;

uint8 block1;//COAP option BLOCK1(PUT or POST),0-6. 2^(4+n)bytes

uint8 block2;//COAP option BLOCK2(GET),0-6. 2^(4+n)bytes

uint8 block2th;//max size to trigger block-wise operation,0-2. 2^(8+n) bytes

} MIPL_T;

void mipl_generate(char *buf, size_t buflen, MIPL_T *mipl);

int main(void)

{

char config[1024];

MIPL_T m5310_mipl_t;

m5310_mipl_t.block1 = MIPL_BLOCK1;

m5310_mipl_t.block2 = MIPL_BLOCK2;

m5310_mipl_t.block2th = MIPL_BLOCK2TH;

m5310_mipl_t.boot = MIPL_BOOT;

m5310_mipl_t.debug = MIPL_DEBUG;

m5310_mipl_t.encrypt = MIPL_ENCRYPT;

m5310_mipl_t.ep_len = strlen((char*)MIPL_ENDPOINT);

m5310_mipl_t.ep = (char*)MIPL_ENDPOINT;

m5310_mipl_t.keep_alive = MIPL_KEEP_ALIVE;

m5310_mipl_t.port = MIPL_PORT;

m5310_mipl_t.uri = (char*)MIPL_URI;

m5310_mipl_t.uri_len = strlen((char*)MIPL_URI);

mipl_generate(config, sizeof(config), &m5310_mipl_t);

while(1);

return 0;

}

void output_buffer(unsigned char *buffer, int length,int index, int flag)

{

int i = 0;

while( i < length )

{

printf( "X", buffer[i++] );

}

printf(",%d,%d\r\n",index,flag);

}

void mipl_generate(char *buf, size_t buflen, MIPL_T *mipl)

{

uint32 offset = 0;

int mipl_num = 0;

char mode = 0;

memset(buf, 0, buflen);

mode = ((mipl->boot & 0x1) << 4) | (mipl->encrypt & 0x1);

memcpy(buf + offset, &mode, 1);

offset++;

memcpy(buf + offset, &mipl->debug, 1);

offset++;

memcpy(buf + offset, &mipl->port, 2);

offset += 2;

memcpy(buf+offset, &mipl->keep_alive, 4);

offset += 4;

memcpy(buf + offset, &mipl->uri_len, 2);

offset += 2;

memcpy(buf + offset, mipl->uri, mipl->uri_len);

offset += mipl->uri_len;

memcpy(buf + offset, &mipl->ep_len, 2);

offset += 2;

memcpy(buf + offset, mipl->ep, mipl->ep_len);

offset += mipl->ep_len;

*(buf + offset) = mipl->block1;

offset++;

*(buf + offset) = mipl->block2;

offset++;

*(buf + offset) = mipl->block2th;

offset++;

mipl_num = 0;

while(offset > 1024)//每条+MIPLCONF命令最多输入1024字节配置数据

{

printf("AT+MIPLCONF=%d,",1024);

output_buffer( (unsigned char *)(buf + (mipl_num >> 10)),1024,mipl_num + 1,0);//index从1起始

mipl_num++;

offset -= 1024;

}

printf("AT+MIPLCONF=%d,",offset);

output_buffer( (unsigned char *)(buf + (mipl_num >> 10)),offset,mipl_num + 1,1);//结束

}

这种方法适用于通过MCU控制M5310模组。

将生成的注册码发送到M5310:

AT+MIPLCONF=71,10000000B80B00001900636F61703A2F2F3138332E3233302E34302E33393A353638331F003836323031383130323931353232303B343630303430323336373039313232050501,1,1

0

OK

0为

4、订阅Object 组 配置

命令格式:AT+MIPLADDOBJ=,,

objectid代表的类型可参考IPSO 资源模型,http://www.openmobilealliance.or ... /LwM2MRegistry.html。

如发送:AT+MIPLADDOBJ=0,3303,0

5、模组侧发起登录

AT+MIPLOPEN=0,15

上述指令中,30 代表登录超时时间;如果超过该时间,模组还未接收到平台的登录响应,模组则会上报登录失败的通知。

登录结果上报:

模组上报登录请求,服务器收到登录请求数据之后,会根据数据内容,返回本次登录结果;如果登录失败,或者登录超时,模组都会上报登录失败的响应。

登录成功上报打印如下:

+MIPLOPEN:0,1

登录失败上报打印如下:

+MIPLOPEN:0,0

需要注意的是, 如果在注册码中的 debug参数设置为非0,则在登录过程中,除了上报登录信息之外,还会应显示对应debug 等级的数据内容。

模组登录成功后,平台会下发Observer 消息和 Discover 消息;模组收到这两条消息之后,会自动处理,无需用户另行处理:

同时OneNET会显示设备在线:

6、向OneNET平台发送数据

命令格式:AT+MIPLNOTIFY=,,,,,,[,]

这里使用不带ackid方法上报:

AT+MIPLNOTIFY=0,3303,0,5700,4,"24.5"

OK

查看上报的数据:

参数说明:

:资源ID,请参考IPSO 资源模型,http://www.openmobilealliance.or ... /LwM2MRegistry.html。

:

123456

stringopaqueintegerfloatboolhex_str

五、命令总结

1、上电检查流程

(1) AT //判断模组是否上电开机成功

(2) AT+CSQ //信号质量检查

(3) AT+CEREG? //判断 PS 域附着状态,标识位返回 1 或 5 表示附着正常

(4) AT+CGATT? //检查模组 PS 附着状态

2、模组侧设备创建及资源订阅,登录流程

(1) AT+MIPLCONF=72,1003000………. 3033393639050501,1,1//设置模组侧设备注册码

(2) AT+MIPLADDOBJ=0,3200,0//订阅 Object 3200 资源设置

(3) AT+MIPLNOTIFY=0,3200,0,5505,6," E309C82FE6 ",1 //订阅 Resource 5500 资源设置

(4) AT+MIPLOPEN=0,30 //设备登录到 OneNET 平台

3、OneNET数据收发流程

(1) AT+MIPLNOTIFY=0,3200,0,5505,6," E309C82FE6 ",1 //数据上传

(2) AT+MIPLREAD=0,60204,3200,0,5505," E309C82FE6 ",1//Read 操作回复流程

(3) AT+MIPLWRITE=0,62069,1 //Write 操作回复流程

(4) AT+MIPLEXECUTE=0,46081,1 //Execute 操作回复流程

4、模组侧设备注销流程

(1) AT+MIPLCLOSE=0//登录注销流程

(2) AT+MIPLDELOBJ=0,3200,0 //模组侧订阅资源列表释放

(3) AT+MIPLDEL=0 //模组侧通信实例删除

六、IPSO 资源模型示例

更多请参考:OMA LightweightM2M (LwM2M) Object and Resource Registry

如果觉得《NBIOT模组M5310接入中国移动物联网开放平台示例文档》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。