Discuz! Board

 ลืมรหัสผ่าน
 ลงทะเบียน
ค้นหา
ดู: 231|ตอบกลับ: 0

สั่งเปิด-ปิดหลอด LED ผ่านมือถือ (ESP8266 เป็น Web Server)

[คัดลอกลิงก์]

16

กระทู้

16

โพสต์

104

เครดิต

ผู้ดูแลระบบ

Rank: 9Rank: 9Rank: 9

เครดิต
104

วงจรและการทำงาน ดังรูป

กำหนดค่าของ board ในโปรแกรม Arduino


จากนั้น ใส่ code ลงไปในโปรแกรม Arduino
  1. // Load Wi-Fi library
  2. #include <ESP8266WiFi.h>

  3. // Replace with your network credentials
  4. const char* ssid     = "REPLACE_WITH_YOUR_SSID";
  5. const char* password = "REPLACE_WITH_YOUR_PASSWORD";

  6. // Set web server port number to 80
  7. WiFiServer server(80);

  8. // Variable to store the HTTP request
  9. String header;

  10. // Auxiliar variables to store the current output state
  11. String output5State = "off";
  12. String output4State = "off";

  13. // Assign output variables to GPIO pins
  14. const int output5 = 5;
  15. const int output4 = 4;

  16. // Current time
  17. unsigned long currentTime = millis();
  18. // Previous time
  19. unsigned long previousTime = 0;
  20. // Define timeout time in milliseconds (example: 2000ms = 2s)
  21. const long timeoutTime = 2000;

  22. void setup() {
  23.   Serial.begin(115200);
  24.   // Initialize the output variables as outputs
  25.   pinMode(output5, OUTPUT);
  26.   pinMode(output4, OUTPUT);
  27.   // Set outputs to LOW
  28.   digitalWrite(output5, LOW);
  29.   digitalWrite(output4, LOW);

  30.   // Connect to Wi-Fi network with SSID and password
  31.   Serial.print("Connecting to ");
  32.   Serial.println(ssid);
  33.   WiFi.begin(ssid, password);
  34.   while (WiFi.status() != WL_CONNECTED) {
  35.     delay(500);
  36.     Serial.print(".");
  37.   }
  38.   // Print local IP address and start web server
  39.   Serial.println("");
  40.   Serial.println("WiFi connected.");
  41.   Serial.println("IP address: ");
  42.   Serial.println(WiFi.localIP());
  43.   server.begin();
  44. }

  45. void loop(){
  46.   WiFiClient client = server.available();   // Listen for incoming clients

  47.   if (client) {                             // If a new client connects,
  48.     Serial.println("New Client.");          // print a message out in the serial port
  49.     String currentLine = "";                // make a String to hold incoming data from the client
  50.     currentTime = millis();
  51.     previousTime = currentTime;
  52.     while (client.connected() && currentTime - previousTime <= timeoutTime) { // loop while the client's connected
  53.       currentTime = millis();         
  54.       if (client.available()) {             // if there's bytes to read from the client,
  55.         char c = client.read();             // read a byte, then
  56.         Serial.write(c);                    // print it out the serial monitor
  57.         header += c;
  58.         if (c == '\n') {                    // if the byte is a newline character
  59.           // if the current line is blank, you got two newline characters in a row.
  60.           // that's the end of the client HTTP request, so send a response:
  61.           if (currentLine.length() == 0) {
  62.             // HTTP headers always start with a response code (e.g. HTTP/1.1 200 OK)
  63.             // and a content-type so the client knows what's coming, then a blank line:
  64.             client.println("HTTP/1.1 200 OK");
  65.             client.println("Content-type:text/html");
  66.             client.println("Connection: close");
  67.             client.println();
  68.             
  69.             // turns the GPIOs on and off
  70.             if (header.indexOf("GET /5/on") >= 0) {
  71.               Serial.println("GPIO 5 on");
  72.               output5State = "on";
  73.               digitalWrite(output5, HIGH);
  74.             } else if (header.indexOf("GET /5/off") >= 0) {
  75.               Serial.println("GPIO 5 off");
  76.               output5State = "off";
  77.               digitalWrite(output5, LOW);
  78.             } else if (header.indexOf("GET /4/on") >= 0) {
  79.               Serial.println("GPIO 4 on");
  80.               output4State = "on";
  81.               digitalWrite(output4, HIGH);
  82.             } else if (header.indexOf("GET /4/off") >= 0) {
  83.               Serial.println("GPIO 4 off");
  84.               output4State = "off";
  85.               digitalWrite(output4, LOW);
  86.             }
  87.             
  88.             // Display the HTML web page
  89.             client.println("<!DOCTYPE html><html>");
  90.             client.println("<head><meta name="viewport" content="width=device-width, initial-scale=1">");
  91.             client.println("<link rel="icon" href="data:,">");
  92.             // CSS to style the on/off buttons
  93.             // Feel free to change the background-color and font-size attributes to fit your preferences
  94.             client.println("<style>html { font-family: Helvetica; display: inline-block; margin: 0px auto; text-align: center;}");
  95.             client.println(".button { background-color: #195B6A; border: none; color: white; padding: 16px 40px;");
  96.             client.println("text-decoration: none; font-size: 30px; margin: 2px; cursor: pointer;}");
  97.             client.println(".button2 {background-color: #77878A;}</style></head>");
  98.             
  99.             // Web Page Heading
  100.             client.println("<body><h1>ESP8266 Web Server</h1>");
  101.             
  102.             // Display current state, and ON/OFF buttons for GPIO 5  
  103.             client.println("<p>GPIO 5 - State " + output5State + "</p>");
  104.             // If the output5State is off, it displays the ON button      
  105.             if (output5State=="off") {
  106.               client.println("<p><a href="/5/on"><button class="button">ON</button></a></p>");
  107.             } else {
  108.               client.println("<p><a href="/5/off"><button class="button button2">OFF</button></a></p>");
  109.             }
  110.                
  111.             // Display current state, and ON/OFF buttons for GPIO 4  
  112.             client.println("<p>GPIO 4 - State " + output4State + "</p>");
  113.             // If the output4State is off, it displays the ON button      
  114.             if (output4State=="off") {
  115.               client.println("<p><a href="/4/on"><button class="button">ON</button></a></p>");
  116.             } else {
  117.               client.println("<p><a href="/4/off"><button class="button button2">OFF</button></a></p>");
  118.             }
  119.             client.println("</body></html>");
  120.             
  121.             // The HTTP response ends with another blank line
  122.             client.println();
  123.             // Break out of the while loop
  124.             break;
  125.           } else { // if you got a newline, then clear currentLine
  126.             currentLine = "";
  127.           }
  128.         } else if (c != '\r') {  // if you got anything else but a carriage return character,
  129.           currentLine += c;      // add it to the end of the currentLine
  130.         }
  131.       }
  132.     }
  133.     // Clear the header variable
  134.     header = "";
  135.     // Close the connection
  136.     client.stop();
  137.     Serial.println("Client disconnected.");
  138.     Serial.println("");
  139.   }
  140. }
คัดลอกไปที่คลิปบอร์ด


ขออภัย! โพสต์นี้มีไฟล์แนบหรือรูปภาพที่ไม่ได้รับอนุญาตให้คุณเข้าถึง

คุณจำเป็นต้อง ลงชื่อเข้าใช้ เพื่อดาวน์โหลดหรือดูไฟล์แนบนี้ คุณยังไม่มีบัญชีใช่ไหม? ลงทะเบียน

x
ขออภัย! คุณไม่ได้รับสิทธิ์ในการดำเนินการในส่วนนี้ กรุณาเลือกอย่างใดอย่างหนึ่ง ลงชื่อเข้าใช้ | ลงทะเบียน

รายละเอียดเครดิต

ข้อความล้วน|อุปกรณ์พกพา|ประวัติการแบน|IoT Inc.

GMT+7, 2021-4-20 18:02 , Processed in 0.095926 second(s), 19 queries .

Powered by Discuz! X3.4, Rev.60

© 2001-2019 Comsenz Inc.

ตอบกระทู้ ขึ้นไปด้านบน ไปที่หน้ารายการกระทู้