AP UDP Server
内容
步骤
- 定义espconn型结构体,网络链接结构体【struct espconn ST_NetCon;】
- 结构体赋值【给ST_NetCon赋值】
- 注册/定义回调函数【
espconn_regist_sentcb(&ST_NetCon, ESP8266_WIFI_Send_Cb);
espconn_regist_recvcb(&ST_NetCon, ESP8266_WIFI_Recv_Cb); 】 - 调用UDP初始化API【espconn_create(&ST_NetCon);】
网络调试助手
代码
头文件
// 头文件引用
//==================================================================================
#include "user_config.h" // 用户配置
#include "driver/uart.h" // 串口
#include "driver/oled.h" // OLED
//#include "at_custom.h"
#include "c_types.h" // 变量类型
#include "eagle_soc.h" // GPIO函数、宏定义
#include "ip_addr.h" // 被"espconn.h"使用。在"espconn.h"开头#include"ip_addr.h"或#include"ip_addr.h"放在"espconn.h"之前
#include "espconn.h" // TCP/UDP接口
//#include "espnow.h"
#include "ets_sys.h" // 回调函数
//#include "gpio.h"
#include "mem.h" // 内存申请等函数
#include "os_type.h" // os_XXX
#include "osapi.h" // os_XXX、软件定时器
//#include "ping.h"
//#include "pwm.h"
//#include "queue.h"
//#include "smartconfig.h"
//#include "sntp.h"
//#include "spi_flash.h"
//#include "upgrade.h"
#include "user_interface.h" // 系统接口、system_param_xxx接口、WIFI、RateContro
//==================================================================================
宏定义
// 宏定义
//==================================================================================
#define ProjectName "AP_UDP_Server" // 工程名宏定义
#define ESP8266_AP_SSID "ESP8266" // 创建的WIFI名
#define ESP8266_AP_PASS "aiot123456" // 创建的WIFI密码
#define LED_ON GPIO_OUTPUT_SET(GPIO_ID_PIN(4),0) // LED亮
#define LED_OFF GPIO_OUTPUT_SET(GPIO_ID_PIN(4),1) // LED灭
//==================================================================================
全局变量
os_timer_t OS_Timer_1; // 软件定时器
struct espconn ST_NetCon; // 注:必须定义为全局变量,内核将会使用此变量(内存)
初始化ESP8266_AP模式
//【与上文一致】
void ICACHE_FLASH_ATTR ESP8266_AP_init()
{
struct softap_config AP_Config; // AP参数结构体
wifi_set_opmode(0x02); // 设置为AP模式,并保存到Flash
// 结构体赋值(注意:【服务集标识符/密码】须设为字符串形式)
//--------------------------------------------------------------------------------------
os_memset(&AP_Config, 0, sizeof(struct softap_config)); // AP参数结构体 = 0
os_strcpy(AP_Config.ssid,ESP8266_AP_SSID); // 设置SSID(将字符串复制到ssid数组)
os_strcpy(AP_Config.password,ESP8266_AP_PASS); // 设置密码(将字符串复制到password数组)
AP_Config.ssid_len=os_strlen(ESP8266_AP_SSID); // 设置ssid长度(和SSID的长度一致)
AP_Config.channel=1; // 通道号1~13
AP_Config.authmode=AUTH_WPA2_PSK; // 设置加密模式
AP_Config.ssid_hidden=0; // 不隐藏SSID
AP_Config.max_connection=4; // 最大连接数
AP_Config.beacon_interval=100; // 信标间隔时槽100~60000 ms
wifi_softap_set_config(&AP_Config); // 设置soft-AP,并保存到Flash
}
关于网络连接的函数
初始化网络连接【ESP8266_NetCon_init】
//esp_udp ST_UDP; // UDP通信结构体
// 初始化网络连接(UDP通信)
//=================================================================================================
void ICACHE_FLASH_ATTR ESP8266_NetCon_init()
{
// ②:结构体赋值
//…………………………………………………………………………………………………
ST_NetCon.type = ESPCONN_UDP; // 通信协议:UDP
// ST_NetCon.proto.udp只是一个指针,不是真正的esp_udp型结构体变量
//-------------------------------------------------------------------------
ST_NetCon.proto.udp = (esp_udp *)os_zalloc(sizeof(esp_udp)); // 申请内存
//ST_NetCon.proto.udp = &ST_UDP;
// 此处无需设置目标IP/端口(ESP8266作为Server,不需要预先知道Client的IP/端口)
//--------------------------------------------------------------------------
//ST_NetCon.proto.udp->local_port = espconn_port(); // 获取8266可用端口
ST_NetCon.proto.udp->local_port = 8266 ; // 设置本地端口
//ST_NetCon.proto.udp->remote_port = 8888; // 设置目标端口
//ST_NetCon.proto.udp->remote_ip[0] = 192; // 设置目标IP地址
//ST_NetCon.proto.udp->remote_ip[1] = 168;
//ST_NetCon.proto.udp->remote_ip[2] = 4;
//ST_NetCon.proto.udp->remote_ip[3] = 2;
//…………………………………………………………………………………………………
// ③:注册/定义回调函数
//-------------------------------------------------------------------------------------------
espconn_regist_sentcb(&ST_NetCon,ESP8266_WIFI_Send_Cb); // 注册网络数据发送成功的回调函数
espconn_regist_recvcb(&ST_NetCon,ESP8266_WIFI_Recv_Cb); // 注册网络数据接收成功的回调函数
// ④:调用UDP初始化API
//----------------------------------------------
espconn_create(&ST_NetCon); // 初始化UDP通信
}
//=================================================================================================
成功接收网络数据的回调函数【ESP8266_WIFI_Recv_Cb】
// 成功接收网络数据的回调函数【参数1:网络传输结构体espconn指针、参数2:网络传输数据指针、参数3:数据长度】
//=========================================================================================================
void ICACHE_FLASH_ATTR ESP8266_WIFI_Recv_Cb(void * arg, char * pdata, unsigned short len)
{
struct espconn * T_arg = arg; // 缓存网络连接结构体指针
remot_info * P_port_info = NULL; // 远端连接信息结构体指针
// 根据数据设置LED的亮/灭
//-------------------------------------------------------------------------------
if(pdata[0] == 'k' || pdata[0] == 'K') LED_ON; // 首字母为'k'/'K',灯亮
else if(pdata[0] == 'g' || pdata[0] == 'G') LED_OFF; // 首字母为'g'/'G',灯灭
os_printf("\nESP8266_Receive_Data = %s\n",pdata); // 串口打印接收到的数据
// 获取远端信息【UDP通信是无连接的,向远端主机回应时需获取对方的IP/端口信息】
//------------------------------------------------------------------------------------
if(espconn_get_connection_info(T_arg, &P_port_info, 0)==ESPCONN_OK) // 获取远端信息
{
T_arg->proto.udp->remote_port = P_port_info->remote_port; // 获取对方端口号
T_arg->proto.udp->remote_ip[0] = P_port_info->remote_ip[0]; // 获取对方IP地址
T_arg->proto.udp->remote_ip[1] = P_port_info->remote_ip[1];
T_arg->proto.udp->remote_ip[2] = P_port_info->remote_ip[2];
T_arg->proto.udp->remote_ip[3] = P_port_info->remote_ip[3];
//os_memcpy(T_arg->proto.udp->remote_ip,P_port_info->remote_ip,4); // 内存拷贝
}
//--------------------------------------------------------------------
OLED_ShowIP(24,6,T_arg->proto.udp->remote_ip); // 显示远端主机IP地址
//--------------------------------------------------------------------
espconn_send(T_arg,"ESP8266_WIFI_Recv_OK",os_strlen("ESP8266_WIFI_Recv_OK")); // 向对方发送应答
}
//=========================================================================================================
成功发送网络数据的回调函数【ESP8266_WIFI_Send_Cb】
// 成功发送网络数据的回调函数
//==========================================================
void ICACHE_FLASH_ATTR ESP8266_WIFI_Send_Cb(void *arg)
{
os_printf("\nESP8266_WIFI_Send_OK\n");
}
//==========================================================
定时的回调函数(查询ESP8266的IP地址,并初始化网络连接)
// 定时的回调函数(查询ESP8266的IP地址,并初始化网络连接)
//=============================================================================================================
void ICACHE_FLASH_ATTR OS_Timer_1_cb(void)
{
struct ip_info ST_ESP8266_IP; // IP信息结构体
u8 ESP8266_IP[4]; // 点分十进制形式保存IP
wifi_get_ip_info(SOFTAP_IF,&ST_ESP8266_IP); // 查询AP模式下ESP8266的IP地址
if(ST_ESP8266_IP.ip.addr != 0) // ESP8266成功获取到IP地址
{
ESP8266_IP[0] = ST_ESP8266_IP.ip.addr; // 点分十进制IP的第一个数 <==> addr低八位
ESP8266_IP[1] = ST_ESP8266_IP.ip.addr>>8; // 点分十进制IP的第二个数 <==> addr次低八位
ESP8266_IP[2] = ST_ESP8266_IP.ip.addr>>16; // 点分十进制IP的第三个数 <==> addr次高八位
ESP8266_IP[3] = ST_ESP8266_IP.ip.addr>>24; // 点分十进制IP的第四个数 <==> addr高八位
// 打印并显示ESP8266的IP地址
//-----------------------------------------------------------------------------------------------
os_printf("ESP8266_IP = %d.%d.%d.%d\n",ESP8266_IP[0],ESP8266_IP[1],ESP8266_IP[2],ESP8266_IP[3]);
OLED_ShowIP(24,2,ESP8266_IP); // OLED显示ESP8266的IP地址
//-----------------------------------------------------------------------------------------------
os_timer_disarm(&OS_Timer_1); // 关闭定时器
ESP8266_NetCon_init(); // 初始化网络连接(UDP通信)
}
}
user_init
// user_init:entry of user application, init user function here
//==============================================================================
void ICACHE_FLASH_ATTR user_init(void)
{
uart_init(115200,115200); // 初始化串口波特率
os_delay_us(10000); // 等待串口稳定
os_printf("\r\n=================================================\r\n");
os_printf("\t Project:\t%s\r\n", ProjectName);
os_printf("\t SDK version:\t%s", system_get_sdk_version());
os_printf("\r\n=================================================\r\n");
// OLED显示初始化
//--------------------------------------------------------
OLED_Init(); // OLED初始化
OLED_ShowString(0,0,"ESP8266 = AP"); // ESP8266模式
OLED_ShowString(0,2,"IP:"); // ESP8266_IP地址
OLED_ShowString(0,4,"Remote = STA"); // 远端主机模式
OLED_ShowString(0,6,"IP:"); // 远端主机IP地址
//--------------------------------------------------------
LED_init(); // LED初始化
ESP8266_AP_init(); // 初始化ESP8266_AP模式
OS_Timer_1_init(1000,1); // 1秒软件定时
}
整体代码
// 头文件引用
//==================================================================================
#include "user_config.h" // 用户配置
#include "driver/uart.h" // 串口
#include "driver/oled.h" // OLED
//#include "at_custom.h"
#include "c_types.h" // 变量类型
#include "eagle_soc.h" // GPIO函数、宏定义
#include "ip_addr.h" // 被"espconn.h"使用。在"espconn.h"开头#include"ip_addr.h"或#include"ip_addr.h"放在"espconn.h"之前
#include "espconn.h" // TCP/UDP接口
//#include "espnow.h"
#include "ets_sys.h" // 回调函数
//#include "gpio.h"
#include "mem.h" // 内存申请等函数
#include "os_type.h" // os_XXX
#include "osapi.h" // os_XXX、软件定时器
//#include "ping.h"
//#include "pwm.h"
//#include "queue.h"
//#include "smartconfig.h"
//#include "sntp.h"
//#include "spi_flash.h"
//#include "upgrade.h"
#include "user_interface.h" // 系统接口、system_param_xxx接口、WIFI、RateContro
//==================================================================================
// 宏定义
//==================================================================================
#define ProjectName "AP_UDP_Server" // 工程名宏定义
#define ESP8266_AP_SSID "ESP8266" // 创建的WIFI名
#define ESP8266_AP_PASS "aiot123456" // 创建的WIFI密码
#define LED_ON GPIO_OUTPUT_SET(GPIO_ID_PIN(4),0) // LED亮
#define LED_OFF GPIO_OUTPUT_SET(GPIO_ID_PIN(4),1) // LED灭
//==================================================================================
// 全局变量
//==================================================================================
os_timer_t OS_Timer_1; // 软件定时器
// 毫秒延时函数
//===========================================
void ICACHE_FLASH_ATTR delay_ms(u32 C_time)
{ for(;C_time>0;C_time--)
os_delay_us(1000);
}
//===========================================
// 初始化ESP8266_AP模式
//============================================================================================
void ICACHE_FLASH_ATTR ESP8266_AP_init()
{
struct softap_config AP_Config; // AP参数结构体
wifi_set_opmode(0x02); // 设置为AP模式,并保存到Flash
// 结构体赋值(注意:【服务集标识符/密码】须设为字符串形式)
//--------------------------------------------------------------------------------------
os_memset(&AP_Config, 0, sizeof(struct softap_config)); // AP参数结构体 = 0
os_strcpy(AP_Config.ssid,ESP8266_AP_SSID); // 设置SSID(将字符串复制到ssid数组)
os_strcpy(AP_Config.password,ESP8266_AP_PASS); // 设置密码(将字符串复制到password数组)
AP_Config.ssid_len=os_strlen(ESP8266_AP_SSID); // 设置ssid长度(和SSID的长度一致)
AP_Config.channel=1; // 通道号1~13
AP_Config.authmode=AUTH_WPA2_PSK; // 设置加密模式
AP_Config.ssid_hidden=0; // 不隐藏SSID
AP_Config.max_connection=4; // 最大连接数
AP_Config.beacon_interval=100; // 信标间隔时槽100~60000 ms
wifi_softap_set_config(&AP_Config); // 设置soft-AP,并保存到Flash
}
//============================================================================================
// 成功发送网络数据的回调函数
//==========================================================
void ICACHE_FLASH_ATTR ESP8266_WIFI_Send_Cb(void *arg)
{
os_printf("\nESP8266_WIFI_Send_OK\n");
}
//==========================================================
// 成功接收网络数据的回调函数【参数1:网络传输结构体espconn指针、参数2:网络传输数据指针、参数3:数据长度】
//=========================================================================================================
void ICACHE_FLASH_ATTR ESP8266_WIFI_Recv_Cb(void * arg, char * pdata, unsigned short len)
{
struct espconn * T_arg = arg; // 缓存网络连接结构体指针
remot_info * P_port_info = NULL; // 远端连接信息结构体指针
// 根据数据设置LED的亮/灭
//-------------------------------------------------------------------------------
if(pdata[0] == 'k' || pdata[0] == 'K') LED_ON; // 首字母为'k'/'K',灯亮
else if(pdata[0] == 'g' || pdata[0] == 'G') LED_OFF; // 首字母为'g'/'G',灯灭
os_printf("\nESP8266_Receive_Data = %s\n",pdata); // 串口打印接收到的数据
// 获取远端信息【UDP通信是无连接的,向远端主机回应时需获取对方的IP/端口信息】
//------------------------------------------------------------------------------------
if(espconn_get_connection_info(T_arg, &P_port_info, 0)==ESPCONN_OK) // 获取远端信息
{
T_arg->proto.udp->remote_port = P_port_info->remote_port; // 获取对方端口号
T_arg->proto.udp->remote_ip[0] = P_port_info->remote_ip[0]; // 获取对方IP地址
T_arg->proto.udp->remote_ip[1] = P_port_info->remote_ip[1];
T_arg->proto.udp->remote_ip[2] = P_port_info->remote_ip[2];
T_arg->proto.udp->remote_ip[3] = P_port_info->remote_ip[3];
//os_memcpy(T_arg->proto.udp->remote_ip,P_port_info->remote_ip,4); // 内存拷贝
}
//--------------------------------------------------------------------
OLED_ShowIP(24,6,T_arg->proto.udp->remote_ip); // 显示远端主机IP地址
//--------------------------------------------------------------------
espconn_send(T_arg,"ESP8266_WIFI_Recv_OK",os_strlen("ESP8266_WIFI_Recv_OK")); // 向对方发送应答
}
//=========================================================================================================
// ①:定义espconn型结构体(网络连接结构体)
//------------------------------------------------------------------------------
struct espconn ST_NetCon; // 注:必须定义为全局变量,内核将会使用此变量(内存)
//esp_udp ST_UDP; // UDP通信结构体
// 初始化网络连接(UDP通信)
//=================================================================================================
void ICACHE_FLASH_ATTR ESP8266_NetCon_init()
{
// ②:结构体赋值
//…………………………………………………………………………………………………
ST_NetCon.type = ESPCONN_UDP; // 通信协议:UDP
// ST_NetCon.proto.udp只是一个指针,不是真正的esp_udp型结构体变量
//-------------------------------------------------------------------------
ST_NetCon.proto.udp = (esp_udp *)os_zalloc(sizeof(esp_udp)); // 申请内存
//ST_NetCon.proto.udp = &ST_UDP;
// 此处无需设置目标IP/端口(ESP8266作为Server,不需要预先知道Client的IP/端口)
//--------------------------------------------------------------------------
//ST_NetCon.proto.udp->local_port = espconn_port(); // 获取8266可用端口
ST_NetCon.proto.udp->local_port = 8266 ; // 设置本地端口
//ST_NetCon.proto.udp->remote_port = 8888; // 设置目标端口
//ST_NetCon.proto.udp->remote_ip[0] = 192; // 设置目标IP地址
//ST_NetCon.proto.udp->remote_ip[1] = 168;
//ST_NetCon.proto.udp->remote_ip[2] = 4;
//ST_NetCon.proto.udp->remote_ip[3] = 2;
//…………………………………………………………………………………………………
// ③:注册/定义回调函数
//-------------------------------------------------------------------------------------------
espconn_regist_sentcb(&ST_NetCon,ESP8266_WIFI_Send_Cb); // 注册网络数据发送成功的回调函数
espconn_regist_recvcb(&ST_NetCon,ESP8266_WIFI_Recv_Cb); // 注册网络数据接收成功的回调函数
// ④:调用UDP初始化API
//----------------------------------------------
espconn_create(&ST_NetCon); // 初始化UDP通信
}
//=================================================================================================
// 定时的回调函数(查询ESP8266的IP地址,并初始化网络连接)
//=============================================================================================================
void ICACHE_FLASH_ATTR OS_Timer_1_cb(void)
{
struct ip_info ST_ESP8266_IP; // IP信息结构体
u8 ESP8266_IP[4]; // 点分十进制形式保存IP
wifi_get_ip_info(SOFTAP_IF,&ST_ESP8266_IP); // 查询AP模式下ESP8266的IP地址
if(ST_ESP8266_IP.ip.addr != 0) // ESP8266成功获取到IP地址
{
ESP8266_IP[0] = ST_ESP8266_IP.ip.addr; // 点分十进制IP的第一个数 <==> addr低八位
ESP8266_IP[1] = ST_ESP8266_IP.ip.addr>>8; // 点分十进制IP的第二个数 <==> addr次低八位
ESP8266_IP[2] = ST_ESP8266_IP.ip.addr>>16; // 点分十进制IP的第三个数 <==> addr次高八位
ESP8266_IP[3] = ST_ESP8266_IP.ip.addr>>24; // 点分十进制IP的第四个数 <==> addr高八位
// 打印并显示ESP8266的IP地址
//-----------------------------------------------------------------------------------------------
os_printf("ESP8266_IP = %d.%d.%d.%d\n",ESP8266_IP[0],ESP8266_IP[1],ESP8266_IP[2],ESP8266_IP[3]);
OLED_ShowIP(24,2,ESP8266_IP); // OLED显示ESP8266的IP地址
//-----------------------------------------------------------------------------------------------
os_timer_disarm(&OS_Timer_1); // 关闭定时器
ESP8266_NetCon_init(); // 初始化网络连接(UDP通信)
}
}
//=============================================================================================================
// 软件定时器初始化(ms毫秒)
//=====================================================================================
void ICACHE_FLASH_ATTR OS_Timer_1_init(u32 time_ms, u8 time_repetitive)
{
os_timer_disarm(&OS_Timer_1); // 关闭定时器
os_timer_setfn(&OS_Timer_1,(os_timer_func_t *)OS_Timer_1_cb, NULL); // 设置定时器
os_timer_arm(&OS_Timer_1, time_ms, time_repetitive); // 使能定时器
}
//=====================================================================================
// LED初始化
//=============================================================================
void ICACHE_FLASH_ATTR LED_init(void)
{
PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO4_U, FUNC_GPIO4); // GPIO4设为IO口
GPIO_OUTPUT_SET(GPIO_ID_PIN(4),1); // IO4 = 1
}
//=============================================================================
// user_init:entry of user application, init user function here
//==============================================================================
void ICACHE_FLASH_ATTR user_init(void)
{
uart_init(115200,115200); // 初始化串口波特率
os_delay_us(10000); // 等待串口稳定
os_printf("\r\n=================================================\r\n");
os_printf("\t Project:\t%s\r\n", ProjectName);
os_printf("\t SDK version:\t%s", system_get_sdk_version());
os_printf("\r\n=================================================\r\n");
// OLED显示初始化
//--------------------------------------------------------
OLED_Init(); // OLED初始化
OLED_ShowString(0,0,"ESP8266 = AP"); // ESP8266模式
OLED_ShowString(0,2,"IP:"); // ESP8266_IP地址
OLED_ShowString(0,4,"Remote = STA"); // 远端主机模式
OLED_ShowString(0,6,"IP:"); // 远端主机IP地址
//--------------------------------------------------------
LED_init(); // LED初始化
ESP8266_AP_init(); // 初始化ESP8266_AP模式
OS_Timer_1_init(1000,1); // 1秒软件定时
}
//==============================================================================
/******************************************************************************
* FunctionName : user_rf_cal_sector_set
* Description : SDK just reversed 4 sectors, used for rf init data and paramters.
* We add this function to force users to set rf cal sector, since
* we don't know which sector is free in user's application.
* sector map for last several sectors : ABCCC
* A : rf cal
* B : rf init data
* C : sdk parameters
* Parameters : none
* Returns : rf cal sector
*******************************************************************************/
uint32 ICACHE_FLASH_ATTR user_rf_cal_sector_set(void)
{
enum flash_size_map size_map = system_get_flash_size_map();
uint32 rf_cal_sec = 0;
switch (size_map) {
case FLASH_SIZE_4M_MAP_256_256:
rf_cal_sec = 128 - 5;
break;
case FLASH_SIZE_8M_MAP_512_512:
rf_cal_sec = 256 - 5;
break;
case FLASH_SIZE_16M_MAP_512_512:
case FLASH_SIZE_16M_MAP_1024_1024:
rf_cal_sec = 512 - 5;
break;
case FLASH_SIZE_32M_MAP_512_512:
case FLASH_SIZE_32M_MAP_1024_1024:
rf_cal_sec = 1024 - 5;
break;
case FLASH_SIZE_64M_MAP_1024_1024:
rf_cal_sec = 2048 - 5;
break;
case FLASH_SIZE_128M_MAP_1024_1024:
rf_cal_sec = 4096 - 5;
break;
default:
rf_cal_sec = 0;
break;
}
return rf_cal_sec;
}
void ICACHE_FLASH_ATTR user_rf_pre_init(void){}
总结模板
// 成功发送网络数据的回调函数
//==========================================================
void ICACHE_FLASH_ATTR ESP8266_WIFI_Send_Cb(void *arg)
{
.......
}
//==========================================================
// 成功接收网络数据的回调函数【参数1:网络传输结构体espconn指针、参数2:网络传输数据指针、参数3:数据长度】
//=========================================================================================================
void ICACHE_FLASH_ATTR ESP8266_WIFI_Recv_Cb(void * arg, char * pdata, unsigned short len)
{
struct espconn * T_arg = arg; // 缓存网络连接结构体指针
remot_info * P_port_info = NULL; // 远端连接信息结构体指针
os_printf("\nESP8266_Receive_Data = %s\n",pdata); // 串口打印接收到的数据
// 获取远端信息【UDP通信是无连接的,向远端主机回应时需获取对方的IP/端口信息】
//------------------------------------------------------------------------------------
if(espconn_get_connection_info(T_arg, &P_port_info, 0)==ESPCONN_OK) // 获取远端信息
{
T_arg->proto.udp->remote_port = P_port_info->remote_port; // 获取对方端口号
T_arg->proto.udp->remote_ip[0] = P_port_info->remote_ip[0]; // 获取对方IP地址
T_arg->proto.udp->remote_ip[1] = P_port_info->remote_ip[1];
T_arg->proto.udp->remote_ip[2] = P_port_info->remote_ip[2];
T_arg->proto.udp->remote_ip[3] = P_port_info->remote_ip[3];
//os_memcpy(T_arg->proto.udp->remote_ip,P_port_info->remote_ip,4); // 内存拷贝
}
espconn_send(T_arg,"ESP8266_WIFI_Recv_OK",os_strlen("ESP8266_WIFI_Recv_OK")); // 向对方发送应答
}
//=========================================================================================================
// ①:定义espconn型结构体(网络连接结构体)
//------------------------------------------------------------------------------
struct espconn ST_NetCon; // 注:必须定义为全局变量,内核将会使用此变量(内存)
//esp_udp ST_UDP; // UDP通信结构体
// 初始化网络连接(UDP通信)
//=================================================================================================
void ICACHE_FLASH_ATTR ESP8266_NetCon_init()
{
// ②:结构体赋值
//…………………………………………………………………………………………………
ST_NetCon.type = ESPCONN_UDP; // 通信协议:UDP
// ST_NetCon.proto.udp只是一个指针,不是真正的esp_udp型结构体变量
//-------------------------------------------------------------------------
ST_NetCon.proto.udp = (esp_udp *)os_zalloc(sizeof(esp_udp)); // 申请内存
//ST_NetCon.proto.udp = &ST_UDP;
// 此处无需设置目标IP/端口(ESP8266作为Server,不需要预先知道Client的IP/端口)
//--------------------------------------------------------------------------
//ST_NetCon.proto.udp->local_port = espconn_port(); // 获取8266可用端口
ST_NetCon.proto.udp->local_port = 8266 ; // 设置本地端口
//ST_NetCon.proto.udp->remote_port = 8888; // 设置目标端口
//ST_NetCon.proto.udp->remote_ip[0] = 192; // 设置目标IP地址
//ST_NetCon.proto.udp->remote_ip[1] = 168;
//ST_NetCon.proto.udp->remote_ip[2] = 4;
//ST_NetCon.proto.udp->remote_ip[3] = 2;
//…………………………………………………………………………………………………
// ③:注册/定义回调函数
//-------------------------------------------------------------------------------------------
espconn_regist_sentcb(&ST_NetCon,ESP8266_WIFI_Send_Cb); // 注册网络数据发送成功的回调函数
espconn_regist_recvcb(&ST_NetCon,ESP8266_WIFI_Recv_Cb); // 注册网络数据接收成功的回调函数
// ④:调用UDP初始化API
//----------------------------------------------
espconn_create(&ST_NetCon); // 初始化UDP通信
}