600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 【安信可NB-IoT模组EC系列应用笔记⑥】AT指令HTTP请求一篇就够

【安信可NB-IoT模组EC系列应用笔记⑥】AT指令HTTP请求一篇就够

时间:2020-09-18 16:22:37

相关推荐

【安信可NB-IoT模组EC系列应用笔记⑥】AT指令HTTP请求一篇就够

AT指令HTTP请求一篇就够

前言一、测试准备二、配置入网1. 指令列表三、HTTP GET请求1. 发送简单的GET请求(1)指令列表:(2)请求结果2.自定义头部的GET请求(1)URL的验证(2)指令列表四、HTTP HEAD请求五、对MCU做OTA升级流程1.获取目标固件信息2.GET请求固件内容(1)整包请求(2)分包请求六、HTTP POST请求1.简单的POST请求2.其他参数的POST请求七. 联系我们

前言

我还记得,EC系列模组教程的前一次更新还是去年,上一篇教程就实现了定位信息监控,可以在微信公众号实时查看EC模组的位置信息(从那以后都不怕自己的小电驴被偷了)。

从本章开始,EC系列会有一系列的教程更新出来,给大家更方便的顺利的使用NB-IOT的功能。本章就教大家如何使用HTTP指令。

一、测试准备

同样的,除了EC-01开发板之外,本次测试需要能够连接网络的NB物联网卡,已经接好配套的天线。开发板的micro USB接入电脑。

apiPost 验证URL是否可以正常响应。(apiPost下载地址:/?utm_source=10120)

EC系列AT指令集:https://docs.ai-/_media/nb-iot/nb-iot系列模组AT指令集v1.0.pdf

二、配置入网

1. 指令列表

AT+CGATT=1\r\nAT+CGDCONT=1,"IP","CMNBIOT1"\r\nAT+CGACT=1\r\nAT+CREG=1\r\n

指令解释:

AT+CGATT ——附着网络

AT+CGDCONT ——配置APN

AT+CGACT ——激活网络

AT+CREG ——注册网络

成功入会打印如下信息:

提示

1、如果在附着网络指令提示:+ CMS ERROR:308,证明物联网卡被锁,通常是换卡使用导致的,需要解锁或者直接换新的卡。

2、如果在配置APN指令时回复:+ CMS ERROR:3。证明附着不成功,或者没装卡导致

3、如果成功之后,后面设备重启可以不发入网的指令,会自动入网

三、HTTP GET请求

1. 发送简单的GET请求

本节我们以/get这个URL为例,控制EC-01-Kit 开发板发送GET请求。

首先使用apiPost验证一下这个URL:

可以看到,这个URL可以正常响应。

(1)指令列表:

AT+HTTPCREATE=0,""\r\nAT+HTTPCON=0\r\nAT+HTTPSEND=0,0,4,"/get"\r\n

重点指令解释:

AT+HTTPSEND=<httpclientId>,<method>,<pathlen>,<path>[,<customheaderlen>,<customheader>,<contentTypelen>,<contentType>,<contentlen>,<content>]

根据指令描述:AT+HTTPSEND=0,0,4,“/get”

参数1:0 为httpclientId 即AT+HTTPCREATE=0,“” 中的“0”

参数2:0 为GET ,1为POST,2为PUT,3为DELETE 4为HEAD

参数3:4 为path 的字符数,即“/get” 的字符数量

参数4 :”/get“为请求的路径,就是path

(2)请求结果

可以看到,响应头和响应数据都分别打印出了,只是响应数据是HEX格式的,只要把这个数据转换成字符串就可以了,在线转换工具:/hexadecimal.html

2.自定义头部的GET请求

(1)URL的验证

自定义头部的请求通常出现在需要验证令牌的情况。因为网上找不到需要自定义头部的HTTP服务器,本次测试为了演示如何使用自定义头部来发送请求,相关URL会关掉,所以不要使用本节的URL进行测试。

HTTP服务器配置如下:

URL:

PATH:/aliyun.DeviceHandler/postFAEData

custom handle:token:fae12345678

我们依旧是先使用apiPost验证一下:

没加token 的请求:

加入token的请求头:

(2)指令列表

根据指令描述,\<customheader>参数要使用16进制表示:

所以,token:fae12345678字符串转换成16进制就是:746f6b656e3a6661653132333435363738

AT+HTTPCREATE=0,""\r\nAT+HTTPCON=0\r\nAT+HTTPSEND=0,0,33,"/aliyun.DeviceHandler/postFAEData",34,"746f6b656e3a6661653132333435363738"\r\n

AT+HTTPSEND 头部参数解释(请同步查看AT指令集)

<customheaderlen>:自定义头部的字符长度----本节自定义头部是:746f6b656e3a6661653132333435363738 长度为:34

<customheader>:自定义头部的内容,以16进制表示。

EC-01-Kit 开发板请求结果:

把数据转换一下:

乱码部分是中文,数据和apiPost 请求的是一样的内容

四、HTTP HEAD请求

HTTP 的HEAD请求其实就是获取目标的响应头。通常在获取目标信息的时候用得到,比如文件大小,MD5值等。HEAD请求和GET请求的指令唯一区别就是AT+HTTPSEND 指令中的第二个参数为4。例如:

//发送GET请求:AT+HTTPSEND=0,0,4,"/get"\r\n//发送HEAD请求:AT+HTTPSEND=0,4,4,"/get"\r\n

五、对MCU做OTA升级流程

EC-01使用AT指令固件,通常需要一个MCU来发送AT指令,随之对MCU进行OTA升级的需求也是必要的。既然讲完了HEAD请求和GET 请求,也可以满足对MCU做固件升级了。

本节使用的固件是随便找了一个ESP8266的固件进行介绍,名字如有雷同,纯属巧合。再者,请不要使用本节的URL进行测试,因为本章写完之后,会修改URL。

提示

NB-IOT 不支持HTTPS,请把固件的URL改成HTTP。

本节的URL为:http://seahibucket1.oss-cn-//http_test/release-v1.5-huawei-ota-0325.bin

1.获取目标固件信息

在升级之前,获取目标固件的信息,固件大小,MD5校验值等,以确定固件的完整和正确。通常情况下,这些信息都在响应头中。这时候我们只需要发送HEAD 请求就可以获取到这些信息。

HEAD请求指令

AT+HTTPCREATE=0,"http://seahibucket1.oss-cn-"\r\nAT+HTTPCON=0\r\nAT+HTTPSEND=0,4,47,"/http_test/release-v1.5-huawei-ota-0325.bin"\r\nAT+HTTPDESTROY=0\r\n

请求结果

可以看到:

Content-Length: 766304Content-MD5: h6AwnvNCs8AERGX4QLQeqQ==

这两个信息,就是目标固件的大小和MD5值。

2.GET请求固件内容

(1)整包请求

EC-01的GET请求的数据内容最大可以到3000 Byte。无法整包请求。而且过程不可控制。

指令列表

AT+HTTPCREATE=0,"http://seahibucket1.oss-cn-"\r\nAT+HTTPCON=0\r\nAT+HTTPSEND=0,0,47,"/http_test/release-v1.5-huawei-ota-0325.bin"\r\n

请求结果

注意

请求下载的数据是原数据的HEX值,MCU是不能直接运行的,需要把这些数据使用算法转换成字符串才是原始数据,才能使用。

例如:

(2)分包请求

分包请求不是差分包升级,而是对整包进行连续的内容下载,直到下载完整个固件包的内容。实现方式就是在请求头中加入Ranges参数,比如:需要下载前0-1024个字节,Ranges:bytes=0-1024,而下一个包的首个字节的位置就是1025,下一次请求头中 Ranges:bytes=1025-1025+xxx。

指令列表,请求前两个包,每包1024Byte

AT+HTTPCREATE=0,"http://seahibucket1.oss-cn-"\r\nAT+HTTPCON=0\r\nAT+HTTPSEND=0,0,47,"/http_test/release-v1.5-huawei-ota-0325.bin",36,"52616e67653a62797465733d302d31303234"\r\nAT+HTTPSEND=0,0,47,"/http_test/release-v1.5-huawei-ota-0325.bin",42,"52616e67653a62797465733d313032352d32303439"\r\n

请求结果

同样的,这些数据都是要进行HEX到字符串的转换。并且把转换后的数据用MD5验证,确保数据正确。

六、HTTP POST请求

POST请求和GET请求的参数大致一样,唯一不同的是POST要是使用Body信息

1.简单的POST请求

我们需用以下信息作为HTTP服务器:

URL:/postBody 类型:application/jsonBody 类型长度:16Body:{“form”:{“purpose”:“test”}}Body的16进制表示:7b22666f726d223a7b22707572706f7365223a2274657374227d7dBody长度:54

指令列表为:

AT+HTTPCREATE=0,""\r\nAT+HTTPCON=0\r\nAT+HTTPSEND=0,1,5,"/post",,,16,"application/json",88,"6170706c69636174696f6e2f6a736f6e3d7b22666f726d223a7b22707572706f7365223a2274657374227d7d"\r\n

请求结果

2.其他参数的POST请求

其他参数的POST请求,可以完全参考GET请求的方式。

七. 联系我们

以上就是本期分享的内容,目的在于让大家快速适应新品方案的开发,更多资料可从我们官网上获取。

官方官网:https://www.ai-

开发资料:https://docs.ai-/

官方论坛:http://bbs.ai-

技术支持:support@

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