Bootstrap

ESP-IDF HTTP POST请求发送音频-启明云端乐鑫代理商

ESP32 HTTP POST请求发送音频

ESP32中 有 HTTP 相关的请求 demo,但是 demo 中只是简单的 HTTP headers 加上 body。如果服务器对 POST 请求有要求,比如数据以 key-value 的形式传输,那么服务器会无法正常处理请求。

POST请求

什么是 POST

POST 是 HTTP 的请求方法,主要用于向指定资源提交数据进行处理请求(例如提交表单或者上传文件),数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。

Post请求一般由请求行请求头请求体组成。下面列举一段简单的 post 请求数据,并加以说明。

POST /api/v1/resource HTTP/1.1
Host: example.com
Content-Type: application/json
Content-Length: 56

{
    "name": "John Doe",
    "email": "[email protected]"
}
POST /api/v1/resource HTTP/1.1

#这一部分是请求行,包含了请求的类型(POST)、请求的路径(/api/v1/resource)以及使用的 HTTP 协议版本(HTTP/1.1)。
Host: example.com
Content-Type: application/json
Content-Length: 56

#这一部分是请求头,提供了关于请求的附加信息。包括目标主机(Host)、内容类型(Content-Type)和请求体的长度(Content-Length)。

注意:请求头和请求体中间有个空行!

{
    "name": "John Doe",
    "email": "[email protected]"
}

#这一部分是请求的主体部分,包含了要发送的数据(在这个例子中是JSON格式的用户信息)。

POST请求发送音频

通过 postman 工具,在获取请求的数据内容后,把请求行、请求头、请求体拼接。

其中,需要传输的音频通过 [spiffs 文件](SPIFFS 文件系统 - ESP32 - — ESP-IDF 编程指南 latest 文档)系统读写,

void http_send_mp3(){
    //读取音频文件
    //...
    long file_size = ftell(file);
    char *file_content = malloc(file_size);
    //file_content 是获取的音频数据, file_size 是音频数据的长度
    fread(file_content, 1, file_size, file);
    //...
    
    esp_http_client_config_t config = {
        .url = POST_URL,
        .event_handler = http_event_handler,
        .method = HTTP_METHOD_POST,
    };
    esp_http_client_handle_t client = esp_http_client_init(&config);
    
     char *post_data = malloc(file_size + 512);
    memset(post_data, 0, file_size + 512);
    memcpy(post_data, "------WebKitFormBoundary7MA4YWxkTrZu0gW\r\nContent-Disposition: form-data; name=\"file\"; filename=\"test.mp3\"\r\nContent-Type: audio/mpeg\r\n\r\n", 135);
    memcpy(post_data + 135, file_content, file_size);
    memcpy(post_data + 135 + file_size, "\r\n------WebKitFormBoundary7MA4YWxkTrZu0gW--\r\n", 45);

    esp_http_client_set_post_field(client, post_data, 180 + file_size);
    esp_err_t err = esp_http_client_perform(client);
    esp_http_client_cleanup(client);
	}
}

//name=“file”,file即为服务器需要post请求携带的key。

确保拼接的格式与 postman 中的报文一致,如遇服务器无法正常处理的现象,可以用 wireshark 或者其他抓包软件抓包,看看 esp32 发送的 POST 报文 body 中的数据格式跟用 POSTMAN 发送的报文一致。

参考链接

https://github.com/espressif/esp-idf/tree/master/examples/protocols/esp_http_client
https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/protocols/esp_http_server.html#http

;