问题描述
我有两块板 AiThinker A7 和 A9G GSM/GPRS/GPS MOdules。我在两块板上使用相同的 SIM 卡将数据发送到 TCP 服务器。它适用于 A7 模块,而在 A9G 模块上出错。 日志如下:
对于 AiThinker A7 Board
AT
OK
AT+GPS=1
OK
AT+copS=0
OK
AT+CGATT=1
+CTZV:21/02/11,03:10:47,+01
OK
AT+CSTT="pinternet.interkom.de","",""
OK
AT+CIICR
OK
AT+CIPSTART="TCP","0.tcp.ngrok.io",16939
CONNECT OK
OK
AT+CIPSEND=138,"{ scooterId: 'C45ZA1',pm25: 234,pm10: 110 }"
OK
+CIPRCV:160,127.0.0.1:49915 said { scooterId: 'C45ZA1',pm10: 110 }
对于 A9G 板
AT+GPS=1
OK
AT+copS=0
OK
AT+CREG?
+CREG: 1,5
OK
AT+CGACT?
+CGACT: 0,0
OK
AT+CGACT=1
OK
AT+CGATT=1
+CGATT:1
OK
AT+CGACT?
+CGACT: 0,0
OK
AT+CSTT="pinternet.interkom.de",""
OK
AT+CIICR
OK
AT+CIPSTART="TCP",16939
+cme ERROR: 50
+cme ERROR: 50
表示 EXE_FAIL。请帮帮我。我想不通。我尝试了很多。
这是为了了解发生了什么而发送的另一组命令。
对于 A7(工作):
AT+CGACT?
+CGACT: 0,0
OK
AT+CGACT=1
OK
AT+CGACT?
+CGACT: 0,0
AT+CGDCONT?
+CGDCONT:1,"pinternet.interkom.de",0
OK
对于 A9G(不工作):
AT+CGATT=1
+CGATT:1
OK
AT+CGACT?
+CGACT: 0,0
OK
AT+CGACT=1,1
OK
AT+CGACT?
+CGACT: 1,1
OK
AT+CGDCONT?
+CGDCONT:1,"10.163.72.91",0
OK
AT+CGDCONT=1,0
+cme ERROR: 3
(错误 3 => OPERATION_NOT_ALLOWED)
解决方法
TL;DR
您需要使用命令正确设置APN名称
AT+CGDCONT=1,"IP","pinternet.interkom.de"
说明
为了到达分组网络,蜂窝设备需要启用 PDP 上下文,然后连接到由特定 APN(接入点名称)标识的接入点。
在您后面的比较测试中,很明显工作模块中的 APN 如何正确设置为 "pinternet.interkom.de"
,而在 A9G 设备中似乎设置为私有 IP 地址.如果没有有效的 APN,设备将无法访问网络。
您后来尝试使用 +CGDCONT
命令设置它,但是您使用了错误的语法。正确的语法是,如 the specification 中所述,是
AT+CGDCONT=[<cid>[,<PDP_type>[,<APN>[,<PDP_addr>[,<d_comp>[,<h_comp>[,<IPv4AddrAlloc>,<request_type>[,<PCSCF_discovery>[,<IM_CN_Signalling_Flag_Ind>[,<NSLPI>[,<securePCO>]]]]]]]]]]]]
您不需要大部分可选参数。你只需要
AT+CGDCONT=<cid>,<PDP_type>,<APN>
所以基本上你错过了 <PDP_type>
参数。它可以设置为值 "IP"
、"IPV6"
、IPV4V6
等,根据您所在网络的功能。根据您的需要,您需要设置它到"IP"
。
https://docs.ai-thinker.com/en/gprs/examples 帮助了我。有效的确切顺序是:
Init...
+CIEV: "Charging",100%
+CREG: 2
^STN: 37
+CTZV:21/02/13,02:51:53,+01
+CREG: 1
A9/A9G
V02.02.20190915R
Ai_Thinker_Co._Ltd.
READY
+CIEV: "Complete the Charge",100%
AT
OK
AT+CGATT=1
+CGATT:1
OK
AT+CGDCONT=1,"pinternet.interkom.de"
OK
AT+CGACT=1,1
OK
AT+CIPSTART="TCP","0.tcp.ngrok.io",12279
CONNECT OK
OK
+CIPRCV,39:SSH-2.0-OpenSSH_7.4p1 Debian-10+deb9u6
CLOSED
OK
AT+CIPSTART="TCP",12973
CONNECT OK
OK
AT+CIPSEND=138,"{ scooterId: 'C45ZA1',pm25: 234,pm10: 110 }"
OK
在向 TCP 发送数据时省略以下命令,有效。序列中的排除命令是:
AT+CSTT="pinternet.interkom.de","",""
OK
AT+CIICR
OK