สารบัญ:
2025 ผู้เขียน: John Day | [email protected]. แก้ไขล่าสุด: 2025-01-13 06:58
คำแนะนำนี้อธิบายวิธีที่เราสามารถใช้บอร์ด Node MCU เพื่อรวบรวมข้อมูลจากเซ็นเซอร์หลายตัว ส่งข้อมูลนี้ไปยังไฟล์ PHP ที่โฮสต์ ซึ่งจะเพิ่มข้อมูลลงในฐานข้อมูล MySQL ข้อมูลสามารถดูออนไลน์เป็นกราฟได้โดยใช้ chart.js
จำเป็นต้องมีความรู้พื้นฐานเกี่ยวกับ PHP และ MySQL สำหรับโครงการนี้ และคุณจะต้องเข้าถึงเว็บโฮสติ้งด้วยการตั้งค่าเหล่านี้จึงจะสามารถสร้างและดูกราฟของคุณเองได้ ฉันยังถือว่าคุณมีความรู้พื้นฐานเกี่ยวกับการใช้บอร์ด Node MCU และการอัปโหลดภาพร่าง (ฉันใช้ Arduino IDE สำหรับสิ่งนี้)
ขั้นตอนที่ 1: สร้างวงจร
เนื่องจาก Node MCU มีพินอะนาล็อกเพียงพินเดียว เราจะใช้มัลติเพล็กซ์เพื่อให้สามารถอ่านข้อมูลจากเซ็นเซอร์หลายตัวได้ (คำแนะนำจำนวนมากครอบคลุมแนวคิดนี้ในรายละเอียดมากขึ้น ดังนั้นฉันจะไม่พูดถึงที่นี่) ในตัวอย่างนี้ ฉันใช้เซ็นเซอร์สองตัว (สำหรับแสงและอุณหภูมิ) แต่คุณสามารถเปลี่ยนเป็นอะไรก็ได้ที่คุณต้องการ และเพิ่มเซ็นเซอร์เพิ่มเติมได้หากต้องการ ฉันใช้ตัวต้านทานที่ไวต่อแสง เทอร์มิสเตอร์ ไดโอดเรียงกระแสสองตัว ตัวต้านทาน 330 โอห์ม และตัวต้านทาน 10K และสายจัมเปอร์สองสามตัว แผนภาพ Fritzing ที่แนบมาแสดงให้เห็นว่าสิ่งเหล่านี้เชื่อมต่อกันอย่างไรบนเขียงหั่นขนม
ขั้นตอนที่ 2: แก้ไขและอัปโหลด Sketch ไปยัง Node MCU
ใช้ไฟล์.ino ที่แนบมานี้ คุณจะต้องแก้ไขสิ่งนี้ด้วยชื่อเครือข่าย WiFi และรหัสผ่านของคุณเอง เพื่อให้ Node MCU สามารถเชื่อมต่อกับเครือข่ายของคุณเองได้
ที่ด้านล่างของร่างนี้ บรรทัด 'delay(60000);' ให้การหน่วงเวลาเป็นนาทีระหว่างการอ่านเซ็นเซอร์ แต่สามารถปรับให้เหมาะกับความต้องการของคุณได้ ฉันขอแนะนำให้ปล่อยทิ้งไว้อย่างน้อย 10 วินาทีเพื่อให้สามารถเชื่อมต่อกับไฟล์ 'updater.php' ได้ในแต่ละครั้ง
คุณจะต้องแก้ไขพาธไปยังตำแหน่งที่คุณจะโฮสต์ไฟล์.php สองไฟล์ และไฟล์จาวาสคริปต์สองไฟล์ที่จำเป็น คุณสามารถดาวน์โหลดได้ในขั้นตอนถัดไป
ขั้นตอนที่ 3: ฐานข้อมูลและไฟล์เว็บ
สร้างฐานข้อมูล MySql ของคุณ สร้างตารางชื่อ 'temp_light' (คุณสามารถเปลี่ยนได้ แต่จะต้องแก้ไขไฟล์ php สองไฟล์เพื่อให้สอดคล้องกับการเปลี่ยนแปลงใดๆ ที่คุณทำ) ให้ตารางสี่เขตข้อมูล ฟิลด์การเพิ่มอัตโนมัติหลัก ฟิลด์จำนวนเต็มชื่อ 'temp' ฟิลด์จำนวนเต็มชื่อ 'light' และฟิลด์ชื่อ 'date_time' ซึ่งจะเป็นการประทับเวลาและค่าเริ่มต้น 'CURRENT_TIMESTAMP'
ตอนนี้ดาวน์โหลดไฟล์.zip ที่แนบมาแล้วแตกไฟล์ออก สิ่งนี้จะให้ไฟล์ php สองไฟล์และโฟลเดอร์ชื่อ 'scripts' ซึ่งมีไฟล์.js ที่ฉันได้รับจาก chartjs.org ไฟล์.js ทั้งสองไฟล์ไม่จำเป็นต้องแก้ไข และโฟลเดอร์ 'scripts' ควรโฮสต์อยู่ในตำแหน่งเดียวกับไฟล์ php สองไฟล์ของคุณ ไฟล์ php ทั้งสองไฟล์จะต้องแก้ไขด้วยชื่อ databse รหัสผ่านและโฮสต์ IP ของคุณเอง ที่อยู่.
ในไฟล์ index.php คุณจะเห็นบรรทัดที่ 50: $adjusted_temp=($temp*0.0623);
การคำนวณนี้คือการแปลงค่าที่อ่านได้สำหรับอุณหภูมิให้ใกล้ที่สุดเท่าที่ฉันจะได้องศาเซนติเกรด และได้มาจากการลองผิดลองถูก และเกือบจะแน่นอนว่าจะต้องมีการเปลี่ยนแปลงเพื่อให้เหมาะกับเซ็นเซอร์อุณหภูมิของคุณเอง
ตอนนี้โฮสต์ทั้งไฟล์ php และโฟลเดอร์ 'scripts' ที่มีไฟล์.js สองไฟล์รวมกันในไดเร็กทอรีเดียวกัน เรียกดูไดเร็กทอรีนั้นและคุณควรเห็นกราฟของคุณเองพร้อมข้อมูลที่ส่งจากบอร์ด Node MCU ของคุณ
ขั้นตอนที่ 4: ผลลัพธ์ที่เสร็จสิ้น
เดิมทีฉันทำโครงการนี้เมื่อประมาณสองปีที่แล้ว แต่ยังไม่เคยเขียนคำสั่งสอนมาจนถึงตอนนี้ คุณสามารถดูกราฟที่สร้างโดยการทดสอบของฉันได้ที่นี่:
หนามแหลมขนาดใหญ่ในกราฟคือจุดที่ดวงอาทิตย์ส่องผ่านหน้าต่างไปยังเซ็นเซอร์สองตัว และการลดลงอย่างช้าๆ อีกครั้งคือเมื่อดวงอาทิตย์ค่อยๆ ลับตาไป