วันพฤหัสบดีที่ 30 พฤศจิกายน พ.ศ. 2560

Arduino Web Server with Ethernet Shield W5100 (อธิบายการทำงานเบื่องต้น) บทที่ 1

ไม่มีความคิดเห็น

Arduino Web Sever (อธิบายการทำงานเบื่องต้น)


      เราจะรวบคุม Arduino ผ่านเน็ตได้เราต้องมี Ethernet Shild W5100  ต่อกับ Arduino แล้วเราก็เอาสายแลนจาก Router มาต่อกับ Ethernet Shild หลักการง่ายมากครับ เหมือนเราใช้มือถือ หรือ คอมพิวเตอร์ ต่อกับ Router แล้ว Router มันจะแจก IP addressให้เราครับ IP addressจะเปลี่ยนไปทุกครั้งที่เราเชื่อมต่อ เมื่อเราได้ IP address Arduino แล้ว เราก็เอา IP address Arduino มาวาง ที่วางลิ้ง  สมมุติ ผมจะเข้า google ผมก็เอา www.google.com มาวางในที่ใส่ URL แต่ถ้าผมต้องการเข้า Arduino ผ่านเว็บผมก็เอา URL ของ Arduinoมาวาง เช่น 192.168.1.1 
    เมื่อเราได้ IP address ของ Arduino มาแล้ว เราต้องเขียนหน้าเว็บใส่ไปใน Arduino ด้วยครับ  เราสามารถเอาค่าจาก Arduinoมาขึ้นที่เว็บได้ หรือ จะเอาคำสั่งที่เรากดในเว็บ ส่งมาให้ Arduino ทำงานก็ได้ครับ
 ตรวจสอบ IP address  Arduino
สิ่งแรกที่เราต้องทำคือ เราต้องรู้ก่อนว่า Router แจก IP address อะไรให้ Arduino เราโดยใช้ Codeนี้ตรวจสอบ

/*
* Simple Client to display IP address obtained from DHCP server
* Arduino 1.0 version
*/
#include "SPI.h"
#include "Ethernet.h"

byte mac[] = { 0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED };
byte server[] = { 173,194,126,119 }; // www.google.co.th

EthernetClient client;

void setup()
{
Serial.begin(9600);
if(Ethernet.begin(mac) == 0) { // start ethernet using mac & DHCP
Serial.println("Failed to configure Ethernet using DHCP");
while(true) // no point in carrying on, so stay in endless loop:
;
}
delay(1000); // give the Ethernet shield a second to initialize

Serial.print("This IP address: ");
IPAddress myIPAddress = Ethernet.localIP();
Serial.print(myIPAddress);
if(client.connect(server, 80)>0) {
Serial.println(" connected");
client.println("GET /search?q=arduino HTTP/1.0");
client.println();
} else {
Serial.println("connection failed");
}
}

void loop()
{
if (client.available()) {
char c = client.read();
// uncomment the next line to show all the received characters
// Serial.print(c);
}

if (!client.connected()) {
Serial.println();
Serial.println("disconnecting.");
client.stop();
for(;;)
;
}
}

เราจะได้ IP address Arduino มดูใน Serial Monitor จะได้ตามนี้ครับ
 


การส่งค่าจาก Arduino มาแสดงบน Web Broswer
ต่อมาเราจะอ่านค่า Analog read  จากArduino มาแสดงใน web Broswer
คำสั่งหลักๆ ที่ใช้คือ  client.print() และ  client.println() ซึ่งจะเป็นการส่งข้อความ
แบบ HTMLไปแสดงบน web Broswer ครับ ลักษณะการเขียน ถ้าสังเกตดูจะเป็นการ
เขียนโปรแกรนบน Arduino IDE เพื่อสร้าง HTML CODE ครับ

 
/*
Web Server

A simple web server that shows the value of the analog input pins.
using an Arduino Wiznet Ethernet shield.

Circuit:
* Ethernet shield attached to pins 10, 11, 12, 13
* Analog inputs attached to pins A0 through A5 (optional)

created 18 Dec 2009
by David A. Mellis
modified 9 Apr 2012
by Tom Igoe

*/

#include
#include

// Enter a MAC address and IP address for your controller below.
// The IP address will be dependent on your local network:
byte mac[] = {
0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED };

// Initialize the Ethernet server library
// with the IP address and port you want to use
// (port 80 is default for HTTP):
EthernetServer server(80);

void setup() {
// Open serial communications and wait for port to open:
Serial.begin(9600);
while (!Serial) {
; // wait for serial port to connect. Needed for Leonardo only
}


// start the Ethernet connection and the server:
Ethernet.begin(mac);
server.begin();
Serial.print("server is at ");
Serial.println(Ethernet.localIP());
}


void loop() {
// listen for incoming clients
EthernetClient client = server.available();
if (client) {
Serial.println("new client");
// an http request ends with a blank line
boolean currentLineIsBlank = true;
while (client.connected()) {
if (client.available()) {
char c = client.read();
Serial.write(c);
// if you've gotten to the end of the line (received a newline
// character) and the line is blank, the http request has ended,
// so you can send a reply
if (c == '\n' && currentLineIsBlank) {
// send a standard http response header
client.println("HTTP/1.1 200 OK");
client.println("Content-Type: text/html");
client.println("Connection: close"); // the connection will be closed after completion of the response
client.println("Refresh: 5"); // refresh the page automatically every 5 sec
client.println();
client.println("");
client.println("");
// output the value of each analog input pin
for (int analogChannel = 0; analogChannel < 6; analogChannel++) {
int sensorReading = analogRead(analogChannel);
client.print("analog input ");
client.print(analogChannel);
client.print(" is ");
client.print(sensorReading);
client.println("
");
}
client.println("");
break;
}
if (c == '\n') {
// you're starting a new line
currentLineIsBlank = true;
}
else if (c != '\r') {
// you've gotten a character on the current line
currentLineIsBlank = false;
}
}
}
// give the web browser time to receive the data
delay(1);
// close the connection:
client.stop();
Serial.println("client disonnected");
}
}
 

เมื่อใส่ Ip address Arduino ลงไปในช่อง URL จะเจอหน้าเว็บนี้ครับ เป็นหน้าเว็บที่เราเขียนใส่ลงไปใน Arduino อ่านค่า Analog read


ไม่มีความคิดเห็น :

แสดงความคิดเห็น