一种简易的ESP32图文Web服务器的实现方式

无意间发现这篇文章,觉得挺有意思的,分享一下:
https://randomnerdtutorials.com/display-images-esp32-esp8266-web-server/

功能很简洁,就是让ESP32作为图文Web服务器。文字好说,如何存储图片呢?我们知道通常Web Server一般把图片以文件或二进制流的形式存在可用存储上,那么在ESP32中又当如何?

文章给出了三种方式:
1、代码中直接“盗图”
2、图文存放在SPIFFS里(更接近传统方式)
3、直接编码图片到img标签中,依靠客户端浏览器功能还原(真第一次注意到还能这么玩)。实现是简单,但不适合大图片,并且需要有工具生成base64代码。

本文采用第三种方式。

需要额外下载两个库:
https://github.com/me-no-dev/ESPAsyncWebServer
https://github.com/me-no-dev/AsyncTCP

下载ZIP包即可,然后Arduino IDE里添加.zip库即可。
图片的base64代码工具。。。我不知道有啥推荐的,原文中有个在线上传。不过我没用,因为如果用C#自己写,核心代码其实就一句话:

string strBase64 = Convert.ToBase64String(File.ReadAllBytes(@"图片文件绝对路径"));

Arduino参考代码:

#include <WiFi.h>
#include <ESPAsyncWebServer.h>

const char* ssid     = "你的WIFI SSID";
const char* password = "你的WIFI密码";

AsyncWebServer server(80);

const char index_html[] PROGMEM = R"rawliteral(
<!DOCTYPE HTML><html>
<head>
  <meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
  <h2>ESP Image Web Server</h2>
  <img src="">
  </body>  
</html>)rawliteral";


void setup(){
  // Serial port for debugging purposes
  Serial.begin(115200);
  
  // Connect to Wi-Fi
  WiFi.begin(ssid, password);
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.println("Connecting to WiFi..");
  }

  // Print ESP32 Local IP Address
  Serial.println(WiFi.localIP());

  // Route for root / web page

  server.on("/", HTTP_GET, [](AsyncWebServerRequest *request){
    request->send_P(200, "text/html", index_html);
  });

  // Start server
  server.begin();
}
 
void loop(){
  
}

编译前可以先开一个串口监视器,网络连接成功后会显示当前IP地址。然后浏览器里打开这个IP,效果如下:

发布了122 篇原创文章 · 获赞 61 · 访问量 53万+

猜你喜欢

转载自blog.csdn.net/ki1381/article/details/105619559
今日推荐