ESP32 Kiểm tra Nhiệt độ qua Web
Trong hướng dẫn này, chúng ta sẽ khám phá quá trình lập trình ESP32 để hoạt động như một web server, cho phép bạn truy cập dữ liệu nhiệt độ qua giao diện web. Sử dụng cảm biến nhiệt độ DS18B20 được kết nối, bạn có thể dễ dàng kiểm tra nhiệt độ hiện tại bằng cách dùng smartphone hoặc PC để truy cập trang web do ESP32 cung cấp. Dưới đây là tổng quan ngắn gọn về cách hoạt động:
- ESP32 được lập trình như một web server.
- Bạn nhập địa chỉ IP của ESP32 vào trình duyệt web trên smartphone hoặc PC.
- ESP32 phản hồi yêu cầu từ trình duyệt web với một trang web chứa nhiệt độ đọc được từ cảm biến DS18B20.

Chúng ta sẽ đi qua hai ví dụ code:
- Code ESP32 cung cấp một trang web rất đơn giản hiển thị nhiệt độ từ cảm biến DS18B20. Điều này giúp bạn dễ dàng hiểu cách hoạt động. Nội dung HTML được nhúng trong code ESP32
- Code ESP32 cung cấp một trang web có đồ họa hiển thị nhiệt độ từ cảm biến DS18B20, nội dung HTML được tách riêng khỏi code ESP32.
Phần Cứng Cần Thiết
| 1 | × | mô-đun phát triển ESP-WROOM-32 | ||
| 1 | × | Alternatively, ESP32 Uno-form board | ||
| 1 | × | Alternatively, ESP32 S3 Uno-form board | ||
| 1 | × | Cáp USB Type-C | ||
| 1 | × | Cảm biến nhiệt độ DS18B20 (CÓ Adapter) | ||
| 1 | × | Cảm biến nhiệt độ DS18B20 (KHÔNG Adapter) | ||
| 1 | × | Dây nối Jumper | ||
| 1 | × | (Khuyến nghị) Screw Terminal Expansion Board for ESP32 | ||
| 1 | × | (Khuyến nghị) Breakout Expansion Board for ESP32 | ||
| 1 | × | (Khuyến nghị) Power Splitter for ESP32 |
Or you can buy the following kits:
| 1 | × | DIYables ESP32 Starter Kit (ESP32 included) | ||
| 1 | × | DIYables Sensor Kit (30 sensors/displays) | ||
| 1 | × | DIYables Sensor Kit (18 sensors/displays) |
Về ESP32 Web Server và Cảm biến nhiệt độ DS18B20
Nếu bạn chưa biết về ESP32 Web Server và cảm biến nhiệt độ DS18B20 (chân kết nối, cách hoạt động, cách lập trình ...), hãy tìm hiểu trong các hướng dẫn sau:
Sơ đồ Kết nối

This image is created using Fritzing. Click to enlarge image
Nếu bạn chưa rõ cách cấp nguồn cho ESP32 và các linh kiện khác, xem: Cách Cung Cấp Nguồn Điện Cho ESP32.
Code ESP32 - Trang Web Đơn giản
Các Bước Thực hiện
- Nếu đây là lần đầu bạn sử dụng ESP32, hãy xem ESP32 - Cài Đặt Phần Mềm.
- Thực hiện kết nối như hình trên.
- Kết nối bo mạch ESP32 với PC của bạn qua cáp micro USB
- Mở Arduino IDE trên PC.
- Chọn đúng bo mạch ESP32 (ví dụ: ESP32 Dev Module) và cổng COM.
- Mở Library Manager bằng cách click vào biểu tượng Library Manager trên thanh điều hướng bên trái của Arduino IDE.
- Tìm kiếm "DIYables ESP32 WebServer", sau đó tìm thư viện Web Server được tạo bởi DIYables.
- Click nút Install để cài đặt thư viện Web Server.

- Tìm kiếm "DallasTemperature" trong ô tìm kiếm, sau đó tìm thư viện DallasTemperature của Miles Burton.
- Click nút Install để cài đặt thư viện DallasTemperature.

- Bạn sẽ được yêu cầu cài đặt dependency. Click nút Install All để cài đặt thư viện OneWire.

- Sao chép code trên và mở bằng Arduino IDE
- Thay đổi thông tin wifi (SSID và password) trong code thành thông tin của bạn
- Click nút Upload trên Arduino IDE để upload code lên ESP32
- Mở Serial Monitor
- Kiểm tra kết quả trên Serial Monitor.
- Bạn sẽ tìm thấy một địa chỉ IP. Nhập địa chỉ IP này vào thanh địa chỉ của trình duyệt web trên smartphone hoặc PC.
- Bạn sẽ thấy kết quả sau trên Serial Monitor.
- Bạn sẽ thấy một trang web rất đơn giản của bo mạch ESP32 trên trình duyệt web như dưới đây:

※ Lưu ý:
Với code được cung cấp ở trên, để có được cập nhật nhiệt độ, bạn phải reload lại trang trên trình duyệt web. Trong phần tiếp theo, chúng ta sẽ học cách làm cho trang web cập nhật giá trị nhiệt độ ở chế độ nền mà không cần reload lại trang web.
Code ESP32 - Trang Web có Đồ họa
Vì một trang web có đồ họa chứa một lượng lớn nội dung HTML, việc nhúng nó vào code ESP32 như trước trở nên bất tiện. Để giải quyết vấn đề này, chúng ta cần tách code ESP32 và code HTML thành các tệp khác nhau:
- Code ESP32 sẽ được đặt trong tệp .ino.
- Code HTML (bao gồm HTML, CSS, và Javascript) sẽ được đặt trong tệp .h.
Để biết chi tiết về cách tách code HTML khỏi code ESP32, vui lòng tham khảo hướng dẫn ESP32 - Web Server.
Các Bước Thực hiện
- Mở Arduino IDE và tạo sketch mới, Đặt tên cho nó, ví dụ: newbiely.com.ino
- Sao chép code dưới đây và mở bằng Arduino IDE
- Thay đổi thông tin WiFi (SSID và password) trong code thành thông tin của bạn
- Tạo tệp index.h trên Arduino IDE bằng cách:
- Click vào nút ngay dưới biểu tượng serial monitor và chọn New Tab, hoặc sử dụng phím tắt Ctrl+Shift+N.
- Đặt tên tệp là index.h và click nút OK
- Sao chép code dưới đây và dán vào index.h.
- Bây giờ bạn có code trong hai tệp: newbiely.com.ino và index.h
- Click nút Upload trên Arduino IDE để upload code lên ESP32
- Truy cập trang web của bo mạch ESP32 qua trình duyệt web trên PC hoặc smartphone như trước. Bạn sẽ thấy như dưới đây:
- Nếu bạn sửa đổi nội dung HTML trong index.h và không thay đổi gì trong tệp newbiely.com.ino, khi bạn compile và upload code lên ESP32, Arduino IDE sẽ không cập nhật nội dung HTML.
- Để Arduino IDE cập nhật nội dung HTML trong trường hợp này, hãy thực hiện một thay đổi trong tệp newbiely.com.ino (ví dụ: thêm dòng trống, thêm comment....)



※ Lưu ý: