ในโปรเจคนี้เราจะสร้างเว็บเซิร์ฟเวอร์ ESP8266 โดยใช้ NodeMCU V3 กับ เซ็นเซอร์ DHT22 แสดงอุณหภูมิและความชื้น
อุปกรณ์ที่ใช้
1. NodeMCU V3 CH340G Lua WIFI ESP8266 ESP-12E
2. Micro USB Cable Wire 1m for NodeMCU
3. DHT22/AM2302 เซ็นเซอร์วัดอุณหภูมิและความชื้น
4. รีซิสเตอร์ 4.7K Ohm 1/4W 5%
5. Breadboard 8.5CM x 5.5CM 400 holes (โฟโต้บอร์ด) จำนวน 2 ชิ้น
6. Jumper (M2M) cable 10 cm
7. รางถ่าน AA 6 ก้อน 9 โวลต์
8. แผ่นอะคริลิคใส ขนาด 10 x 12.5 เซนติเมตร
1. ประกอบ วงจร
ประกอบ Breadboard 2 ชิ้น ลงบน แผ่นอะคริลิคใส ขนาด 10 x 12.5 เซนติเมตร
และ ประกอบ NodeMCU V3 ลงบน Breadboard
และ ประกอบ NodeMCU V3 ลงบน Breadboard
data:image/s3,"s3://crabby-images/09e76/09e76a4a6a1974222c24ff6ca610c09953657d56" alt=""
ประกอบวงจรตามรูป
data:image/s3,"s3://crabby-images/d3e26/d3e263cbf2397a2f7149b2fdc848ddec5995c3be" alt=""
data:image/s3,"s3://crabby-images/80fcd/80fcd601bf60014d7ec6aa723872d5b975a8a915" alt=""
เชื่อมต่อรางถ่าน เข้ากับ Breadboard
โดยสายสีแดง ไฟ+ ไปยังขา VIN ของ NodeMCU V3 และ สายสีดำ ไฟ- ไปยัง กราวด์ (GND) ของ Breadboard
data:image/s3,"s3://crabby-images/02b8d/02b8d5393470cad9a4fd55ea58c63b28fffd4387" alt=""
2. ตรวจสอบการติดตั้งไดร์เวอร์ ของ NodeMCU V3
เสียบสาย USB จากคอมพิวเตอร์ เข้ากับ NodeMCU V3
data:image/s3,"s3://crabby-images/7a280/7a280910516e5b3e2d173579e817262719fdfbaa" alt=""
ตรวจสอบการติดตั้งไดร์เวอร์ ของ NodeMCU V3
โดย คลิกขวา Computet -> Properties
(ถ้าไม่พบให้ทำการติดตั้งไดร์เวอร์ก่อน)
ตัวอย่างการติดตั้งไดร์เวอร์ ชิฟ CH340G
3. ติดตั้ง แพลตฟอร์ม ESP8266
การจะใช้ NodeMCU ได้นั้น จำเป็นต้องติดตั้ง แพลตฟอร์ม ESP8266 เพื่อ ทำการติดต่อ ระหว่าง Arduino IDE กับ NodeMCU
ลิงค์ : ขั้นตอนการติดตั้ง แพลตฟอร์ม ESP8266
https://robotsiam.blogspot.com/2017/06/esp8266-platform-nodemcu.html
4. ติดตั้ง Library ของ DHT Sensor
การจะใช้ DHT22/AM2302 เซ็นเซอร์วัดอุณหภูมิและความชื้น ได้นั้น จำเป็นต้องติดตั้ง ไลบรารี DHT เพิ่มเข้าไปยัง Arduino IDE ของเรา
ลิงค์ : การติดตั้ง Library ของ DHT Sensor
5. อัพโหลด โค้ด
การกำหนดชื่อ Pin นั้น สามารถใช้ได้ 2 แบบ คือ แบบที่ 1 จะ อ้างตามชื่อ Pin บนบอร์ด NodeMCU V3 เป็น D1 หรือ แบบที่ 2 เป็นการเทียบขา ตามรูปด้านล่าง โดยเลือกใช้ Pin เป็น 5 ก็ได้เช่นกัน
เสียบสาย USB จากคอมพิวเตอร์ เข้ากับ NodeMCU V3
data:image/s3,"s3://crabby-images/a3da8/a3da887ca82dbbbb69b371c9231ad90574618a07" alt=""
เปิดโปรแกรม Arduino IDE ก๊อบปี้ โค้ด ด้านล่างไปยัง โปรแกรม ของ Arduino IDE
// Including the ESP8266 WiFi library
#include <ESP8266WiFi.h>
#include "DHT.h"
// Uncomment one of the lines below for whatever DHT sensor type you're using!
//#define DHTTYPE DHT11 // DHT 11
//#define DHTTYPE DHT21 // DHT 21 (AM2301)
#define DHTTYPE DHT22 // DHT 22 (AM2302), AM2321
// Replace with your network details
const char* ssid = "YOUR_NETWORK_NAME";
const char* password = "YOUR_NETWORK_PASSWORD";
// Web Server on port 80
WiFiServer server(80);
// DHT Sensor
const int DHTPin = 5; // D1
// Initialize DHT sensor.
DHT dht(DHTPin, DHTTYPE);
// Temporary variables
static char celsiusTemp[7];
static char fahrenheitTemp[7];
static char humidityTemp[7];
// only runs once on boot
void setup() {
// Initializing serial port for debugging purposes
Serial.begin(115200);
delay(10);
dht.begin();
// Connecting to WiFi network
Serial.println();
Serial.print("Connecting to ");
Serial.println(ssid);
WiFi.begin(ssid, password);
while (WiFi.status() != WL_CONNECTED) {
delay(500);
Serial.print(".");
}
Serial.println("");
Serial.println("WiFi connected");
// Starting the web server
server.begin();
Serial.println("Web server running. Waiting for the ESP IP...");
delay(10000);
// Printing the ESP IP address
Serial.println(WiFi.localIP());
}
// runs over and over again
void loop() {
// Listenning for new clients
WiFiClient client = server.available();
if (client) {
Serial.println("New client");
// bolean to locate when the http request ends
boolean blank_line = true;
while (client.connected()) {
if (client.available()) {
char c = client.read();
if (c == '\n' && blank_line) {
// Sensor readings may also be up to 2 seconds 'old' (its a very slow sensor)
float h = dht.readHumidity();
// Read temperature as Celsius (the default)
float t = dht.readTemperature();
// Read temperature as Fahrenheit (isFahrenheit = true)
float f = dht.readTemperature(true);
// Check if any reads failed and exit early (to try again).
if (isnan(h) || isnan(t) || isnan(f)) {
Serial.println("Failed to read from DHT sensor!");
strcpy(celsiusTemp,"Failed");
strcpy(fahrenheitTemp, "Failed");
strcpy(humidityTemp, "Failed");
}
else{
// Computes temperature values in Celsius + Fahrenheit and Humidity
float hic = dht.computeHeatIndex(t, h, false);
dtostrf(hic, 6, 2, celsiusTemp);
float hif = dht.computeHeatIndex(f, h);
dtostrf(hif, 6, 2, fahrenheitTemp);
dtostrf(h, 6, 2, humidityTemp);
// You can delete the following Serial.print's, it's just for debugging purposes
Serial.print("Humidity: ");
Serial.print(h);
Serial.print(" %\t Temperature: ");
Serial.print(t);
Serial.print(" *C ");
Serial.print(f);
Serial.print(" *F\t Heat index: ");
Serial.print(hic);
Serial.print(" *C ");
Serial.print(hif);
Serial.print(" *F");
Serial.print("Humidity: ");
Serial.print(h);
Serial.print(" %\t Temperature: ");
Serial.print(t);
Serial.print(" *C ");
Serial.print(f);
Serial.print(" *F\t Heat index: ");
Serial.print(hic);
Serial.print(" *C ");
Serial.print(hif);
Serial.println(" *F");
}
client.println("HTTP/1.1 200 OK");
client.println("Content-Type: text/html");
client.println("Connection: close");
client.println();
// your actual web page that displays temperature and humidity
client.println("<!DOCTYPE HTML>");
client.println("<html>");
client.println("<head></head><body><h1>RobotSiam - Temperature and Humidity</h1><h3>Temperature in Celsius: ");
client.println(celsiusTemp);
client.println("*C</h3><h3>Temperature in Fahrenheit: ");
client.println(fahrenheitTemp);
client.println("*F</h3><h3>Humidity: ");
client.println(humidityTemp);
client.println("%</h3><h3>");
client.println("</body></html>");
break;
}
if (c == '\n') {
// when starts reading a new line
blank_line = true;
}
else if (c != '\r') {
// when finds a character on the current line
blank_line = false;
}
}
}
// closing the client connection
delay(1);
client.stop();
Serial.println("Client disconnected.");
}
}
ก่อนการอัพโหลดต้องแก้ไขโค้ด ตรงสีแดงให้ถูกต้องก่อน โดย
ssid = "ชื่อwifiที่ต้องการเชื่อมต่อ"
password = "รหัสผ่าน"
data:image/s3,"s3://crabby-images/7a1e9/7a1e92e34444659a962256a847fdc5edfcc8831e" alt=""
อัพโหลด.... (ควรต่อไฟเข้า 9 โวลต์ ที่ขา VIN และ GND ขณะอัพโหลดด้วย)
data:image/s3,"s3://crabby-images/f06f2/f06f2e1c11d90448eeaec8fca373ed21f48ff5f3" alt=""
รอจนกระทั่ง Done uploading. 100%
data:image/s3,"s3://crabby-images/94528/94528d67b9793f86a8f0166f20c85e25adc6e47d" alt=""
ไปที่ Serial Monitor
data:image/s3,"s3://crabby-images/13a7e/13a7ee1b14e1565119b2c08961ea4cfdb51fe9ba" alt=""
เลือก Both NL & CR และ เลือก 115200 baud
data:image/s3,"s3://crabby-images/26c82/26c82a5d0e032a8c30b4ca00cbc0f6e6a7997474" alt=""
กดปุ่ม RST (อยู่ด้านล่างซ้ายมือ) 1 ครั้ง
data:image/s3,"s3://crabby-images/82752/827525d70e950f3f63d6271e5b206af018cec50e" alt=""
Serial Monitor จะแสดง ไอพี ของ NodeMCU V3 ในตัวอย่างคือ 192.168.1.40
ไปที่ บราวเซอร์ ที่ URL ป้อน 192.168.1.40 ที่ได้จาก Serial Monitor ด้านบน
(ไอพีที่ได้แต่ละครั้งอาจจะไม่เหมือนกัน ให้ตรวจสอบทุกครั้ง)
data:image/s3,"s3://crabby-images/c50b0/c50b02af579cc83e22c92c8944790caeae569250" alt=""
เมื่อกลับไปดูที่ Serial Monitor จะ แสดงอุณหภูมิและความชื้น เพิ่มเข้ามา แสดงว่าโปรเจคของเรานั้นพร้อมทำงานแล้ว
data:image/s3,"s3://crabby-images/dbcec/dbcec13a49d93b0929860af8c0eabf6eda0b5cdd" alt=""
6. ทดสอบการทำงานของโปรเจค
ถอดสาย USB จากคอมพิวเตอร์ ออกจาก NodeMCU V3
วีดีโอผลลัพธ์การทำงานของ โปรเจค NodeMCU V3 กับ DHT22 แสดงอุณหภูมิและความชื้น
ถอดสาย USB จากคอมพิวเตอร์ ออกจาก NodeMCU V3