通过之前http://www.cnblogs.com/noticeable/p/7636582.html中对socket的编程,已经可以知道如何通过socket编程搭建服务器和客户端了,现在,就在ESP32上搭建一个TCP Client进行实际验证。

代码编辑如下:

l#include "freertos/FreeRTOS.h"

#include "esp_wifi.h"

#include "esp_system.h"

#include "esp_event.h"

#include "esp_event_loop.h"

#include "nvs_flash.h"

#include "driver/gpio.h"

#include <esp_log.h>

#include <freertos/FreeRTOS.h>

#include <freertos/task.h>

#include "freertos/queue.h"

#include "freertos/event_groups.h"

#include <lwip/sockets.h>

#include <string.h>

#include "sdkconfig.h"

#define FEEDBACK_DATA            "ESP32_Data"

#define EXAMPLE_WIFI_SSID        "li"//需要连接到的wifi热点的SSID和密码

#define EXAMPLE_WIFI_PASS        "12345678"

static EventGroupHandle_t wifi_event_group;

const int CONNECTED_BIT = BIT0;//添加连接成功消息

static const char *TAG = "main";

static esp_err_t event_handler(void *ctx, system_event_t *event)//终端事件处理

{

    switch(event->event_id) {

    case SYSTEM_EVENT_STA_START:

    ESP_LOGI(TAG, "STA start");

        esp_wifi_connect();//当事件为SYSTEM_EVENT_STA_START时,进行wifi连接

        break;

    case SYSTEM_EVENT_STA_GOT_IP:

    ESP_LOGD(TAG, "Got an IP: " IPSTR, IP2STR(&event->event_info.got_ip.ip_info.ip));//获取连接成功的ip详情

        xEventGroupSetBits(wifi_event_group, CONNECTED_BIT);//设置CONNECTED_BIT事件标志位

        break;

    case SYSTEM_EVENT_STA_DISCONNECTED:

        /* This is a workaround as ESP32 WiFi libs don't currently

           auto-reassociate. */

         esp_wifi_connect();                                                                                    //esp32进行wifi连接

        xEventGroupClearBits(wifi_event_group, CONNECTED_BIT);//清楚事件标志位

        break;

    default:

        break;

    }

    return ESP_OK;

}

static void initialise_wifi(void)//函数初始化WIFI

{

    wifi_config_t wifi_config = {

        .sta = {

            .ssid = EXAMPLE_WIFI_SSID,

            .password = EXAMPLE_WIFI_PASS,

        },//staiton配置要连接到的站点的信息

    };

    tcpip_adapter_init();//

    wifi_event_group = xEventGroupCreate();//创建event_group

    esp_event_loop_init(event_handler, NULL);//

    wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT();

    ESP_ERROR_CHECK(esp_wifi_init(&cfg));//wifi初始化

    ESP_ERROR_CHECK(esp_wifi_set_storage(WIFI_STORAGE_RAM));//设置内存ram

    ESP_ERROR_CHECK(esp_wifi_set_mode(WIFI_MODE_STA));//wifi模式设置

    ESP_ERROR_CHECK(esp_wifi_set_config(ESP_IF_WIFI_STA, &wifi_config));//wifi作为station的一些配置

    ESP_ERROR_CHECK(esp_wifi_start());//wifi开始工作

}

void socketClient(void *ignore) {

    ESP_LOGD(TAG, "start");

    int sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);//创建一个socket套接字

    ESP_LOGD(TAG, "socket: rc: %d", sock);

    struct sockaddr_in serverAddress;//定义一个sockaddr_in的地址结构体

    serverAddress.sin_family = AF_INET;//IPV4协议

    inet_pton(AF_INET, "192.168.191.1", &serverAddress.sin_addr.s_addr);//ip地址转换,将点分十进制转换成二进制整数,这里的"192.168.191.1"为所连接的主机的IP地址,根据自己实际情况填写

    serverAddress.sin_port = htons();//将整型变量从主机字节序转变成网络字节序

    int rc = connect(sock, (struct sockaddr *)&serverAddress, sizeof(struct sockaddr_in));//和TCP服务器建立连接,当TCP调用connect时就会调用一个三次握手过程

    ESP_LOGD(TAG, "connect rc: %d", rc);

    char *data = "Hello world";//要发送的数据

    rc = send(sock, data, strlen(data), );//发送数据

    ESP_LOGD(TAG, "send: rc: %d", rc);

    //rc = close(sock);

    ESP_LOGD(TAG, "close: rc: %d", rc);

    vTaskDelete(NULL);

}

void app_main(void)

{

      nvs_flash_init();//初始化nvs_flash

      initialise_wifi();//初始化wifi设置

    gpio_set_direction(GPIO_NUM_4, GPIO_MODE_OUTPUT);

    int level = ;

    while (true) {

    xEventGroupWaitBits(wifi_event_group, CONNECTED_BIT, false, true, portMAX_DELAY);//创建事件等待位,等待wifi连接事件产生,每有一个connect连接事件就执行其后的程序一次,否则一直等待并执行其他程序

     //   ESP_LOGI(TAG, "Got IP");

     xEventGroupClearBits(wifi_event_group, CONNECTED_BIT);//有连接事件产生

     xTaskCreate(&socketClient, "socketClient", , NULL, , NULL);//发送数据任务

         gpio_set_level(GPIO_NUM_4, level);

         level = !level;

         vTaskDelay( / portTICK_PERIOD_MS);

    }

}

程序编辑完成,程序即完成烧写了,下面就是进行初始的调试测试了。

首先创建一个服务器并启动:

设置完成后,给ESP32上电,即可看到服务器有客户端连接,并接收到了helloworld字符。

最新文章

  1. PDO连接mysql数据库
  2. Zend Framework 项目 index.php 的问题
  3. BZOJ 2844 albus就是要第一个出场 ——高斯消元 线性基
  4. 《UML大战需求分析》阅读笔记6
  5. javascript练习-子类调用父类的构造函数和方法
  6. Visual Studio中设置默认VC++路径
  7. Transfer-Encoding: chunked
  8. .Net中C#的DllImport的用法
  9. JavaScript高级程序设计30.pdf
  10. python代码中pass的用法
  11. yii Query Builder (yii 查询构造器) 官方指南翻译
  12. 再议 js 数字格式之正则表达式
  13. orcale复制表结构及其数据
  14. rzsz的安装
  15. smarty的学习计划(1)
  16. 201521123092《java程序设计》第十周学习总结
  17. udacity/CarND-Path-Planning-Project 工程详细配置过程——吐血整理
  18. Window10下RabbitMQ安装图文教程
  19. 吴裕雄 python 机器学习-NBYS(1)
  20. Centos 6.9 安装Rabbitmq

热门文章

  1. [51Nod 1238] 最小公倍数之和 (恶心杜教筛)
  2. python AES对称加密
  3. Jquery检验输入值
  4. QLocalSocket
  5. [Luogu] 受欢迎的牛
  6. 05_Nginx日志分析
  7. ajax案例_校验用户名
  8. 1821:【00NOIP提高组】乘积最大
  9. pmm的安装,这里推荐下载官方提供的脚本,直接执行这个脚本就可以完成安装
  10. ZR#997