Mục lục:
- Quân nhu
- Bước 1: Xây dựng mạch
- Bước 2: Tổng quan nhanh về hệ thống tệp SPIFFS
- Bước 3: Cài đặt SPIFFS Bootloader trên Mac OS
- Bước 4: Cài đặt thư viện
- Bước 5: Tạo tệp Index.html và Style.css với nội dung sau
- Bước 6: Mã Arduino
- Bước 7: Tải lên mã và tệp Arduino bằng Trình tải SPIFFS
- Bước 8: Xác định địa chỉ IP máy chủ web ESP32
- Bước 9: Kiểm tra Máy chủ Web Cục bộ
- Bước 10: Truy cập vào máy chủ web cục bộ từ mọi nơi trên thế giới bằng Ngrok
2025 Tác giả: John Day | [email protected]. Sửa đổi lần cuối: 2025-01-23 15:15
Tổng quan dự án
Trong ví dụ này, chúng tôi sẽ tìm ra cách tạo một máy chủ web dựa trên ESP32 để điều khiển trạng thái đèn LED, có thể truy cập được từ mọi nơi trên thế giới. Bạn sẽ cần một máy tính Mac cho dự án này, nhưng bạn có thể chạy phần mềm này ngay cả trên một máy tính rẻ tiền và công suất thấp như Raspberry Pi.
Chuẩn bị ESP32 với Arduino IDE
Để bắt đầu lập trình ESP32 bằng Arduino IDE và ngôn ngữ lập trình Arduino, bạn sẽ cần một phần bổ trợ đặc biệt. Đọc về cách chuẩn bị Arduino IDE cho ESP32 trên Mac OS theo liên kết sau.
Quân nhu
Đối với hướng dẫn này, bạn sẽ cần các mục sau:
- Bảng phát triển ESP325mm
- LEDResistor 220ohm
- Màn hình LCD 16x2 với mô-đun I2C
- Breadboard
- Dây nhảy
- Cáp micro USB
Bước 1: Xây dựng mạch
Thực hiện các kết nối như thể hiện trong sơ đồ dưới đây
Bắt đầu bằng cách kết nối đầu ra điện áp cung cấp 3V3 trên bảng mạch điện tử ESP32 và GNDto. Kết nối đèn LED qua điện trở với ESP32 sử dụng chân GPIO 23 làm chân đầu ra kỹ thuật số. Sau đó, kết nối chân SDA của màn hình LCD 16x2 với chân GPIO 21 và SCL với chân GPIO 22.
Bước 2: Tổng quan nhanh về hệ thống tệp SPIFFS
SPIFFS là viết tắt của “Hệ thống tệp Flash giao diện ngoại vi nối tiếp”, tức là hệ thống tệp cho bộ nhớ flash truyền dữ liệu qua SPI. Theo đó, SPIFFS là một hệ thống tệp được đơn giản hóa được thiết kế cho các bộ vi điều khiển có chip flash truyền dữ liệu qua bus SPI (chẳng hạn như bộ nhớ flash ESP32).
SPIFFS hữu ích nhất để sử dụng với ESP32 trong các trường hợp sau:
- Tạo tệp để lưu trữ cài đặt
- Lưu trữ dữ liệu vĩnh viễn.
- Tạo tệp để lưu trữ một lượng nhỏ dữ liệu (thay vì sử dụng thẻ nhớ microSD cho việc này).
- Lưu trữ các tệp HTML và CSS để tạo máy chủ web.
Bước 3: Cài đặt SPIFFS Bootloader trên Mac OS
Bạn có thể tạo, lưu và ghi dữ liệu vào các tệp được lưu trữ trong hệ thống tệp ESP32 trực tiếp bằng cách sử dụng plugin trên Arduino IDE.
Trước hết, hãy đảm bảo rằng bạn đã cài đặt phiên bản Arduino IDE mới nhất, sau đó thực hiện như sau:
- Mở liên kết sau và tải xuống tệp lưu trữ “ESP32FS-1.0.zip”
- Đi tới thư mục Arduino IDE, nằm trên thư mục Documents.
- Tạo một thư mục công cụ, nếu nó không tồn tại. Bên trong thư mục công cụ tạo một thư mục ESP32FS khác. Bên trong ESP32FS tạo một cái khác, được gọi là công cụ.
- Giải nén tệp nén ZIP đã tải xuống ở bước 1 vào thư mục công cụ.
- Khởi động lại Arduino IDE của bạn.
- Để kiểm tra xem plugin đã được cài đặt thành công hay chưa, hãy mở Arduino IDE và nhấp vào “Công cụ” và kiểm tra xem có mục “Tải lên dữ liệu phác thảo ESP32” trong menu này hay không.
Bước 4: Cài đặt thư viện
Các thư viện ESPAsyncWebServer và AsyncTCP cho phép bạn tạo một máy chủ web bằng cách sử dụng các tệp từ hệ thống tệp của ESP32. Để biết thêm thông tin về các thư viện này, hãy kiểm tra liên kết sau.
Cài đặt thư viện ESPAsyncWebServer
- Nhấp vào đây để tải xuống kho lưu trữ ZIP của thư viện.
- Giải nén kho lưu trữ này. Bạn sẽ nhận được thư mục ESPAsyncWebServer-master.
- Đổi tên nó thành "ESPAsyncWebServer".
Cài đặt thư viện AsyncTCP
- Bấm vào đây để tải xuống kho lưu trữ ZIP của thư viện.
- Giải nén kho lưu trữ này. Bạn sẽ nhận được thư mục AsyncTCP-master.
- Đổi tên nó thành “AsyncTCP”.
Di chuyển các thư mục ESPAsyncWebServer và AsyncTCP vào thư mục thư viện, nằm bên trong thư mục Documents.
Cuối cùng, khởi động lại Arduino IDE.
Bước 5: Tạo tệp Index.html và Style.css với nội dung sau
Mẫu HTML / CSS cho nút bật tắt được lấy từ nguồn sau.
Bước 6: Mã Arduino
Chủ yếu, mã dựa trên mã Arduino được lấy từ Máy chủ Web ESP32 bằng SPIFFS và Cách sử dụng I2C LCD với ESP32 trên Arduino IDE.
Bước 7: Tải lên mã và tệp Arduino bằng Trình tải SPIFFS
- Mở thư mục phác thảo của mã Arduino.
- Bên trong thư mục này, tạo một thư mục mới có tên là “dữ liệu”.
- Bên trong thư mục dữ liệu, bạn cần đặt index.html và style.css.
- Tải lên mã Arduino
- Sau đó, để tải tệp lên, hãy nhấp vào IDE Arduino trên Công cụ> Tải lên dữ liệu phác thảo ESP32
Bước 8: Xác định địa chỉ IP máy chủ web ESP32
Nó có thể được tìm thấy theo hai cách.
- Màn hình nối tiếp trên Arduino IDE (Công cụ> Màn hình nối tiếp)
- Trên màn hình LCD
Bước 9: Kiểm tra Máy chủ Web Cục bộ
Tiếp theo, mở trình duyệt web bạn chọn và dán địa chỉ IP sau vào thanh địa chỉ. Bạn sẽ nhận được một đầu ra tương tự như ảnh chụp màn hình bên dưới.
Bước 10: Truy cập vào máy chủ web cục bộ từ mọi nơi trên thế giới bằng Ngrok
Ngrok là một nền tảng cho phép bạn tổ chức truy cập từ xa vào máy chủ web hoặc một số dịch vụ khác chạy trên PC của bạn từ internet bên ngoài. Truy cập được tổ chức thông qua đường hầm an toàn được tạo khi bắt đầu ngrok.
- Theo liên kết này và đăng ký.
- Sau khi tạo tài khoản, hãy đăng nhập và chuyển đến tab "Auth". Sao chép dòng từ trường "Your Tunnel Authtoken".
- Nhấp vào tab “Tải xuống” trên thanh điều hướng, chọn phiên bản ngrok phù hợp với hệ điều hành của bạn và tải xuống.
- Giải nén thư mục đã tải xuống và chạy dòng lệnh.
- Kết nối tài khoản của bạn bằng cách nhập lệnh sau
./ngrok authtoken
Bắt đầu một đường hầm HTTP trên cổng 80
./ngrok http Your_IP_Address: 80
Nếu mọi thứ được thực hiện chính xác, thì trạng thái đường hầm sẽ chuyển thành "trực tuyến" và liên kết chuyển hướng sẽ xuất hiện trong cột "Chuyển tiếp". Bằng cách nhập liên kết này vào trình duyệt của bạn, bạn có thể truy cập máy chủ web từ bất kỳ đâu trên thế giới.
Đề xuất:
ESP 8266 Nodemcu Ws 2812 Đèn LED MOOD dựa trên Neopixel được điều khiển bởi Máy chủ web cục bộ: 6 bước
ESP 8266 Nodemcu Ws 2812 Đèn LED MOOD dựa trên Neopixel được điều khiển bởi Máy chủ web cục bộ: ESP 8266 Nodemcu Ws 2812 Đèn MOOD dựa trên Neopixel được điều khiển bằng máy chủ web
ESP8266 RGB LED STRIP Điều khiển WIFI - NODEMCU làm điều khiển từ xa hồng ngoại cho dải đèn Led được điều khiển qua Wi-Fi - Điều khiển điện thoại thông minh RGB LED STRIP: 4 bước
ESP8266 RGB LED STRIP Điều khiển WIFI | NODEMCU làm điều khiển từ xa hồng ngoại cho dải đèn Led được điều khiển qua Wi-Fi | Điều khiển bằng điện thoại thông minh RGB LED STRIP: Xin chào các bạn trong hướng dẫn này, chúng ta sẽ học cách sử dụng gật đầu hoặc esp8266 làm điều khiển từ xa IR để điều khiển dải LED RGB và Nodemcu sẽ được điều khiển bằng điện thoại thông minh qua wifi. Vì vậy, về cơ bản bạn có thể điều khiển DÂY CHUYỀN LED RGB bằng điện thoại thông minh của mình
ESP 8266 Nodemcu RGB LED Strip được điều khiển bằng điều khiển từ xa của máy chủ web: 4 bước
ESP 8266 Nodemcu RGB LED Strip được điều khiển bằng điều khiển từ xa của máy chủ web: Trong phần hướng dẫn này, chúng ta sẽ tìm hiểu cách chuyển đổi nút thành một điều khiển từ xa hồng ngoại của dải LED RGB và điều khiển từ xa nút đó phải được điều khiển bởi một trang web được lưu trữ trên thiết bị di động hoặc máy tính bằng gật gù
ESP 8266 Nodemcu Ws 2812 Đèn LED MOOD dựa trên Neopixel được điều khiển bằng máy chủ trang web: 6 bước
ESP 8266 Nodemcu Ws 2812 Đèn LED MOOD dựa trên Neopixel được điều khiển bằng máy chủ trang web: Trong Dự án này, chúng tôi sẽ tạo một Đèn MOOD từ nút & neopixel và có thể được kiểm soát bởi bất kỳ trình duyệt nào sử dụng máy chủ web cục bộ
Đồng hồ hoạt ảnh LED SMART được kết nối web với bảng điều khiển dựa trên web, máy chủ thời gian được đồng bộ hóa: 11 bước (có hình ảnh)
Đồng hồ hoạt hình LED thông minh được kết nối web với bảng điều khiển dựa trên web, máy chủ thời gian được đồng bộ hóa: Câu chuyện về chiếc đồng hồ này đã trở lại một chặng đường dài - hơn 30 năm. Cha tôi đã đi tiên phong trong ý tưởng này khi tôi chỉ mới 10 tuổi, rất lâu trước cuộc cách mạng đèn LED - trở lại khi đèn LED có độ sáng 1/1000 so với độ chói lóa hiện tại của chúng. Một sự thật