赞
踩
最近在准备电赛,需要使用到EPS8266-WIFI模块通过手机实现一些功能的运行,在此记录下我的一些笔记。
模块:使用的是正点原子的ATK-ESP8266-V1.3
接线:由于只需要实现一些简介的通信,只需VCC->3.3V,GND->GND,TX-RX,RX->TX,RST和IO可以不用接
通过CH-340(USB转TTL模块)连接到电脑,打开串口调试助手,发送AT(测试指令),若传回"OK"即为成功连接。
下面是一些常用的AT指令,需要勾选发送新行功能才能成功发送
指令名 | 功能 |
---|---|
AT | 测试指令 |
AT+CWMODE= | 设置应用模式(需重启生效), 1:STA 2:AP 3:AP+station |
AT+CWLAP | 返回目前的AP列表 |
AT+CWJAP=, | 加入某一AP |
AT+CWJAP? | 返回当前加入的AP |
AT+CWQAP | 退出当前加入的AP |
AT+CIPSTART=,, | 建立TCP/UDP连接 |
AT+CIPMUX= | 是否启用多连接,0:否,1:是,启用后不可进入透传 |
AT+CIPSEND= | 发送数据 |
AT+CIPMODE= | 是否进入透传模式 |
+++ | 退出透传模式,需要关闭发送新行 |
下面这个例子,使EPS8266连接到现有的WIFI/热点,以电脑为主机进行通信:
AT+CWMODE=1
AT+RST
AT+CWJAP=“abcwifi”,“abc88888”(wifi名字最好不超过6位)
接着,打开网络调试助手,主机类型选择tcp server,ip地址填写主机ip
(ip地址填写主机ip,主机ip查询方式:按下win+r,打开命令框输入cmd,输入ipconfig,IPv4 地址即为主机ip)
AT+CIPSTART=“TCP”,“主机ip”,8080
此时,连接成功,可以通过网络调试助手与串口调试助手互相收发数据
下面这个例子,使EPS8266连接到现有的WIFI/热点,以ESP8266为主机进行通信,这个也是我要接下来一直使用的:
AT+CWMODE=3
AT+CIPMUX=0
AT+RST
AT+CWJAP=“abcwifi”,“abc88888”
AT+CIPSERVER=1
AT+CIFSR
在手机上打开“TCP连接”(一个APP),在成功输入完以上指令后,点击右上角连接,输入IP及端口号,IP为“AT+CIFSR”传回的地址,端口号为默认值333。成功连接后,可通过此APP实现按键输入指定指令,以完成以后要实现的功能。
引用此博主的博文链接: https://blog.csdn.net/qq_38410730/article/details/86538288.
在此基础上进行了一些简单的修改。
ESP8266.C:
#include "esp8266.h" #include "string.h" #include "usart3.h" #include "stm32f10x.h" #include "sys.h" #include "delay.h" #include "usart.h" u8 res=1; void esp8266_start_trans(void) { //设置工作模式 1:station模式 2:AP模式 3:兼容 AP+station模式 esp8266_send_cmd("AT+CWMODE=3","OK",50); //让Wifi模块重启的命令 esp8266_send_cmd("AT+RST","ready",20); delay_ms(1000); //延时2S等待重启成功 delay_ms(1000); //让模块连接上自己的路由 while(esp8266_send_cmd("AT+CWJAP=\"nowifi\",zhr88888\"\"","WIFI GOT IP",600)); //=0:单路连接模式 =1:多路连接模式 esp8266_send_cmd("AT+CIPMUX=1","OK",20); esp8266_send_cmd("AT+CIPSERVER=1","OK",200); } //向ESP8266发送命令 //cmd:发送的命令字符串;ack:期待的应答结果,如果为空,则表示不需要等待应答;waittime:等待时间(单位:10ms) //返回值:0,发送成功(得到了期待的应答结果);1,发送失败 u8 esp8266_send_cmd(u8 *cmd,u8 *ack,u16 waittime) { u8 res=0; USART3_RX_STA=0; u3_printf("%s\r\n",cmd); //发送命令 if(ack&&waittime) //需要等待应答 { while(--waittime) //等待倒计时 { delay_ms(10); if(USART3_RX_STA&0X8000)//接收到期待的应答结果 { if(esp8266_check_cmd(ack)) { printf("ack:%s\r\n",(u8*)ack); break;//得到有效数据 } USART3_RX_STA=0; } } if(waittime==0)res=1; } return res; } //ESP8266发送命令后,检测接收到的应答 //str:期待的应答结果 //返回值:0,没有得到期待的应答结果;其他,期待应答结果的位置(str的位置) u8* esp8266_check_cmd(u8 *str) { char *strx=0; if(USART3_RX_STA&0X8000) //接收到一次数据了 { USART3_RX_BUF[USART3_RX_STA&0X7FFF]=0;//添加结束符 strx=strstr((const char*)USART3_RX_BUF,(const char*)str); } return (u8*)strx; } //向ESP8266发送数据 //cmd:发送的命令字符串;waittime:等待时间(单位:10ms) //返回值:发送数据后,服务器的返回验证码 u8* esp8266_send_data(u8 *cmd,u16 waittime) { char temp[5]; char *ack=temp; waittime=50; USART3_RX_STA=0; u3_printf("%s",cmd); //发送命令 if(waittime) //需要等待应答 { while(--waittime) //等待倒计时 { delay_ms(10); if(USART3_RX_STA&0X8000)//接收到期待的应答结果 { USART3_RX_BUF[USART3_RX_STA&0X7FFF]=0;//添加结束符 ack=(char*)USART3_RX_BUF; printf("%s",(u8*)ack); USART3_RX_STA=0; break;//得到有效数据 } } } return (u8*)ack; }
在main.c中不断循环发送空数据
esp8266_send_data("",50);
//若某时刻通过手机发送指令,例如1,那么此时espnum[0]=1.
espnum[0]=USART3_RX_BUF[11]-'0';
espnum[0]即为发送的指令,至此,stm32关于esp8266的初始化已经完毕。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。