Air780EP是合宙推出的一款低功耗4G全网通模组,兼容模组行业1618经典封装,支持OpenCPU开发及全功能数传AT开发,可广泛应用于多样化的物联网终端。
上周写了基于Air780EP模组AT开发的FOTA远程升级指南,有客户朋友询问能否讲讲HTTP应用部分?本期特别安排——涵盖HTTP基本应用流程、GET/POST/SSL请求示例、断点续传、常见问题等内容。
一、相关准备工作
1.1 硬件准备
合宙EVB_Air780EP开发板一套,包括天线、SIM卡;
USB线
PC电脑
1.2 软件准备
串口调试工具
如果没有准备,推荐使用LLCOM:
https://llcom.papapoi.com
AT固件下载
https://gitee.com/openLuat/airm2m-ec718-at/releases
进入AT固件下载页面按下Ctrl+F,搜索AirM2M_780EP_LTE_AT,即可找到Air780EP模块所使用的AT固件。
本文使用示例为:
AirM2M_780EP_V1007_LTE_AT版本固件
推荐选用:相关型号固件名称后面数字版本号最高的最新relase版本进行调试。
二、HTTP应用基本流程
合宙低功耗4G模块支持HTTP和HTTPS协议,HTTP应用的基本流程如下:
激活PDP
初始化HTTP服务
设置HTTP会话参数
如果要支持SSL,配置SSL参数
如果使用POST命令,输入POST数据
发起HTTP请求
收到HTTP应答,读取应答数据
终止HTTP服务
相关注意事项:
第1步如果出现异常,首先需要排查HTTP连接和请求参数是否正常,通过Postman是否可以请求成功,模块上网是否正常(AT+CEREG?);
第2步到第5步,只要输入格式正确,基本不会出问题;如果出错,可以跳过,直接处理第6步的异常;
第6步和第7步如果出现异常:终止HTTP服务,有选择性的去激活PDP;然后再有选择性的激活PDP,从第2步开始重新执行。
三、HTTP GET请求示例
具体指令和参数使用说明,可参考AT指令手册:
相关注意事项:
01. 请求及应答
发送AT+HTTPACTION命令后,收到OK仅仅表示4G模块开始处理这条命令,并不表示请求发送成功,收到了应答。
只有收到+HTTPACTION: n,statusCode,len才表示请求结束,statusCode表示应答成功,其余都表示应答失败。
02. 数据大小限制
HTTP应答数据的缓冲区大小为4KB,如果返回的http body数据超过了这个大小,则需要断点下载——可以使用AT+HTTPPARA命令,通过设置BREAK和BREAKEND参数来实现。
03. HTTP被动断开
发送AT+HTTPACTION命令,和服务器建立了HTTP连接后,如果连接异常被动断开,会输出+HTTPACTION: ,,提示。
04. PDP被动激活
先来看下PDP被动激活时的AT命令处理序列,如果不理解AT命令含义,请自行参考AT手册。
+PDP DEACT // 出现PDP去激活的URC上报
后面如果没做任何处理,接着做HTTP请求会失败,可以按照下方的建议处理。
应对处理每次结束,都需要重新走一遍HTTP请求流程:
第一种方法:
AT+CIPSHUT // 关闭移动场景
第二种方法:
AT+CIPSHUT // 关闭移动场景
AT+CGDCONT=5,"IP",""//请填写实际APN
AT+CGACT=1,5
第三种方法:
AT+CFUN=0 // 进入飞行模式
AT+CFUN=1 // 退出飞行模式
第四种方法:
AT+RESET // 重启模块
参考下发流程中收到"+SAPBR 1: DEACT"错误提示,表示PDP被动去激活,为异常处理的触发点。
四、HTTP POST请求示例
POST请求流程与GET流程基本一致,只有指令参数:
AT+HTTPACTION=0
变为:
AT+HTTPACTION=1
具体指令和参数使用说明,可参考AT指令手册:
五、HTTPS SSL请求示例
本示例为带SSL证书双向验证功能的HTTPS过程,具体指令和参数使用说明,可参考AT指令手册:
六、HTTP断点续传示例
在实际的应用场景中,可能需要下载一个非常大的文件,例如几百K字节、几M字节,但是4G模块中HTTP可用的内存缓冲区Air780EP模块只有4KB左右。当文件大小超过这个缓冲区时,就要使用断点续传功能来分段下载处理了。
下文以“下载一个119345字节的文件”为例,来说明如何使用断点续传功能(注意:本示例仅仅演示了正常流程的HTTP AT命令,完整流程以及异常处理流程请参考本文应用流程部分)。
七、常见问题Q&A
以下针对客户朋友们实际应用中的反馈,整理了HTTP应用中的常见问题:
01. HTTP支持多连接吗?
目前HTTP仅支持单连接,不支持多连接。
02. HTTPS如何使用?
本文主要描述了基本流程和异常处理,对于HTTPS使用方法没有做过多描述。这一部分,请自行参考AT指令手册HTTP章节下《使用方法举例》中的"带SSL证书验证功能的HTTPS流程"使用方法;支持的SSL参数,请自行参考AT+SSLCFG命令说明。如果SSL的参数配置不变,则每次开机运行过程中,仅设置一次即可。
03. 重试多次PDP,HTTP应用一直连接失败?
如果重试多次PDP激活,PDP一直激活失败,或者HTTP一直请求应答失败,请尝试使用如下手段恢复:
使用RESET引脚复位模块;
极端情况下,直接给模块断电,再上电,POWER KEY引脚拉低开机。
04. HTTP下载的大文件,如何可靠的发送给MCU(AT流控)?
需要在断点续传流程指令里开头加入AT+IFC的配置指令:
AT+HTTPREAD
+HTTPREAD: 3072
...... //此处输出3072字节数据
OK
此处的3072字节数据,是模块通过UART AT口发送给MCU。在实际传输过程中,由于串口芯片驱动、MCU端的处理能力、波特率的选择都存在不确定性,可能会导致MCU端接收到的数据,实际上没有3072字节,这就要求UART AT口打开流控功能。
模块支持硬件流控和软件流控两种:
硬件流控,参考如下步骤操作:
模块和MCU的UART口,CTS、RTS要交叉相连
MCU端固件要支持并且打开硬流控功能
MCU端要发送AT+IFC=2,2命令到模块端,打开模块端的硬流控功能
软件流控,参考如下步骤操作:
MCU端固件要支持并且打开软流控功能
MCU端要发送AT+IFC=1,1命令到模块端,打开模块端的软流控功能
05. 为什么我只发了10字节消息,100次却消耗了很多流量?
因为还有HTTP自带的请求头。
06. 为什么频繁请求会失败?
HTTP连接总数数量有限,且不支持HTTP2多路复用连接,因此建议等一个HTTP连接返回请求结果之后,再去请求下一个连接;不要使用循环定时器方式不断的发起新的HTTP请求。
07. 如何POST文件?
主要是使用AT+HTTPDATA命令录入文件数据后,发送AT+HTTPACTION=1利用POST上传。
08. 数据发送接收缓存问题如何解决?
AT版本有缓存机制,内存中有一个的缓冲区(Air780EP模块AT固件HTTP缓存为4KB),发送和接受使用的是同一块缓冲区。
发送和收到数据后,插入此缓冲区,然后通过AT口输出URC,提示收到的数据长度;缓冲区满之后,再收到新数据,会丢弃新收到的数据,并通过AT口输出URC提示出错;需要读取数据时,发送AT+HTTPREAD命令读取,可分段读取,也可全部读取。
特别注意:
缓冲区位于内存中,断电或者重启后,缓存表中的数据会被清空;虽然缓冲区可以缓存很多数据,但是建议收到数据时,通过AT+HTTPREAD及时读取出来,以防缓冲区满出错。