移远 EC200S 模组(4G Cat.1 通信模组)AT指令测试 TCP/UDP 通信过程

移远EC200S 4G Cat.1 模组

EC200S-CN 是移远通信推出的LTE Cat 1 无线通信模块,支持最大下行速率10Mbps 和最大上行速率5Mbps,具有超高的性价比。

同时在封装上兼容移远通信多网络制式LTE Standard EC2x(EC25、EC21、EC20 R2.0、EC20 R2.1)和EC200T/EG25-G/EG21-G 模块以及UMTS/HSPA+ UC20/UC200T 模块,实现了3G 网络与4G 网络之间的无缝切换。

EC200S-CN 还支持标准的Mini PCIe 封装,以满足不同行业产品应用需求。

1. 环境准备

1.1. 硬件准备

EC200S通信模组(mini PCIE封装)+ PCIE通信模组底座 + USB转串口:

1.2. 软件准备

  • QCOM串口助手
  • EC20通信模组测试AT命令脚本(EC200S.ini)
  • Windows USB 驱动

使用AT指令测试移远EC200S模组有两种方法:

  • ① 第一种是使用USB转串口连接模组。

  • ② 第二种是安装官方提供的驱动,然后直接使用USB线连接到模组,使用虚拟AT串口测试。

本文使用第一种方法,将模组直接通过USB转串口连接到电脑。

使用QCOM工具打开该串口,波特率115200-8-N-1:

1.3. 文档准备

此文档来自于移远官方!阅读本教程时,关于AT指令的详细说明请参考该文档!

2. 模组信号查询与网络查询AT指令

AT

指令:AT

功能:测试AT指令功能是否正常

示例:

AT

OK

AT+CPIN?

指令:AT+CPIN?

功能:查询SIM卡是否正常,返回ready则表示SIM卡正常

示例,如果SIM卡插入成功,则返回结果为:

AT+CPIN?

+CPIN: READY

OK

如果未插入SIM卡,则返回结果为:

AT+CPIN?

+CME ERROR: 10

AT+CSQ

指令:AT+CSQ

功能:查询模组的信号强度,第一个值为0-31则正常,99为不正常

示例:

AT+CSQ

+CSQ: 17,0

OK

此处有问题,模组实际返回+CSQ:22,99

AT+CREG?

指令:AT+CREG?

功能:查询模组是否注册上GSM网络,+CREG:0,1 表示已注册上本地网,+CREG:0,5表示注册上漫游网。

示例:

AT+CREG?

+CREG: 0,1

OK

AT+CGREG?

指令:AT+CERGE?

功能:查询模组是否注册上GPRS网络,+CGREG:0,1 表示已注册上本地网,+CGREG:0,5表示注册上漫游网。

示例:

AT+CGREG?

+CGREG: 0,1

OK

3. 激活移动场景

必须在查询GPRS网络已正常注册网络的情况下进行本节实验!

AT+QICSGP=1,1,“CMNET”

指令:AT+QICSGP=1,1,“CMNET”

功能:设置GPRS的APN,移动CMNET,联通UNINET

示例:

AT+QICSGP=1,1,"CMNET"

OK

AT+QIDEACT=1

指令:AT+QIDEACT=1
功能:在激活GPRS场景之前先关闭GPRS场景,确保连接正确

示例:

AT+QIDEACT=1
OK

AT+QIACT=1

指令:AT+QIACT=1

功能:激活移动场景

示例:

AT+QIACT=1

OK

4. 基于 TCP 协议连接远程服务器通信实例

4.1. 搭建远程TCP服务器

首先我们需要搭建一个TCP服务器,有两种方式:

  • 在服务器上使用Python、Java、C#等语言自行编写服务器程序;
  • 在本地PC上使用网络调试助手开启TCP服务器;

因为EC20模组直接注册的是公网ip地址,所以这里我们使用第一种方式,在Linux服务器上运行一个Python编写的tcp测试服务器:

本地PC使用的是局域网,公网不可以直接根据ip地址访问到本PC,需要进行内网穿透,不推荐使用。

这里的Python程序如下:

# tcpserver.py

from socket import *

host = ''
port = 8902

# 创建server socket
server_socket = socket(AF_INET,SOCK_STREAM)

# 绑定socket监听地址
server_addr = (host,port)
server_socket.bind(server_addr)

# 开始监听,最大允许连接数5
server_socket.listen(5)

# 处理连接请求
try:
    while True:
        print('waiting for connect...')
        #阻塞等待客户端的连接 
        client_socket, client_addr = server_socket.accept()
        # 连接成功后,打印客户端信息
        print('a client connnect from:', client_addr)

        while(True):
            # 向客户端发送数据
            client_socket.send('Hello, client!'.encode())

            # 接收客户端的数据
            data = client_socket.recv(1024)
            print('recv data is ', data.decode())

            # 接收到quit则关闭socket
            if "quit" in data.decode():
                break
        
        # 关闭socket
        client_socket.close()
        server_socket.close()
        print("socket closed.")
        break
except:
    client_socket.close()
    server_socket.close()
    print("socket closed.")

运行:

python3 tcp-server.py

效果如下:

4.2. 模组连接服务器

使用AT命令连接TCP服务器,其中第一个参数是协议类型,“TCP”则表示使用TCP协议,第二个参数是TCP服务器ip地址,也可以使用域名,最一个参数是TCP服务器开启监听的端口:

AT+QIOPEN=<contextID>,<connectID>,<service_type>,<IP_address>/<domain_name>,<remote_port>[,<local_port>[,<access_mode>]]

最后一个参数access_mode是接收模式配置,0-缓冲区接收方式,1-直接接收方式

示例:

AT+QIOPEN=1,0,"TCP","117.50.111.72",8902,0,0

OK

+QIOPEN: 0,0

连接之后,在服务器端也可以看到:

4.2. 模组接收消息

模组连接到服务器后,服务器会自动发送消息,模组还没有配置,所以直接打印出了:

+QIURC: "recv",0

使用命令读取数据:

AT+QIRD=0,1500

+QIRD: 14
Hello, client!

OK

如果上一步建立socket时配置为直接接收模式,效果如下:

+QIURC: "recv",0,14
Hello, client!

4.3. 模组主动发送消息

发送文本消息

使用如下的命令即可向TCP服务器发送消息,首先设置要发送数据的字节数,等待模组返回>后,输入要发送的数据即可,如果发送的数据超过了设置的n个字节,则只发送前n个字节,后面的数据被认为是无效数据,不会发送:

AT+QISEND=0

>hello<0x1a>

示例:

AT+QISEND=0

> hello

SEND OK

发送成功看服务器上运行的TCP服务器是否收到:

发送十六进制字符串

该命令用于发送 16 进制字符串数据:

AT+QISENDEX=<connectID>,<hex_string>

命令参数说明:

  • connectID:整型,socket ID,范围:0-11;
  • hex_string:字符串类型,16进制字符串数据,最长512字节

模组响应结果为:

  • 发送成功:SEND OK
  • 发送缓存已满:SEND FAIL
  • 连接不存在:ERROR

示例:

AT+QISENDEX=0,"303132333435"

SEND OK

服务器接收结果为:

4.4. 关闭TCP连接

通信完毕之后,可以使用下面的命令关闭TCP连接:

AT+QICLOSE=<connectID>[,<timeout>]

示例:

AT+QICLOSE=0

OK

5. 域名解析

指令:

AT+QIDNSGIP=<contextID>,<hostname>

功能:域名解析

返回内容:

+QIURC: "dnsgip",<err>,<IP_count>,<DNS_ttl>
……
+QIURC: "dnsgip",<hostIPaddr>

返回参数说明:

  • err:整型,操作错误代码;
  • IP_count:表示该域名对应几个ip;
  • DNS_ttl:DNS的TTL值;
  • hostIPaddr:域名解析出的ip地址;

示例:

AT+QIDNSGIP=1,"www.mculover666.cn"

OK

+QIURC: "dnsgip",0,1,600

+QIURC: "dnsgip","122.51.89.94"

解析百度:

AT+QIDNSGIP=1,"www.baidu.com"

OK

+QIURC: "dnsgip",0,2,10

+QIURC: "dnsgip","183.232.231.174"

+QIURC: "dnsgip","183.232.231.172"

接收更多精彩文章及资源推送,欢迎订阅我的微信公众号:『mculover666』。

猜你喜欢

转载自blog.csdn.net/Mculover666/article/details/108290138