IP Configuration
This commit is contained in:
@@ -0,0 +1,167 @@
|
||||
/*
|
||||
WiFi Web Server
|
||||
|
||||
A simple web server that shows the value of the analog input pins.
|
||||
using a WiFi shield.
|
||||
|
||||
This example is written to configure the WiFi settings using provisioning mode.
|
||||
It also sets up an mDNS server so the IP address of the board doesn't have to
|
||||
be obtained via the serial monitor.
|
||||
|
||||
Circuit:
|
||||
WiFi shield attached
|
||||
Analog inputs attached to pins A0 through A5 (optional)
|
||||
|
||||
created 13 July 2010
|
||||
by dlf (Metodo2 srl)
|
||||
modified 31 May 2012
|
||||
by Tom Igoe
|
||||
|
||||
*/
|
||||
|
||||
#include <SPI.h>
|
||||
#include <WiFi101.h>
|
||||
#include <WiFiMDNSResponder.h>
|
||||
|
||||
const int ledPin = 6; // LED pin for connectivity status indicator
|
||||
|
||||
char mdnsName[] = "wifi101"; // the MDNS name that the board will respond to
|
||||
// after WiFi settings have been provisioned
|
||||
// Note that the actual MDNS name will have '.local' after
|
||||
// the name above, so "wifi101" will be accessible on
|
||||
// the MDNS name "wifi101.local".
|
||||
|
||||
WiFiServer server(80);
|
||||
|
||||
// Create a MDNS responder to listen and respond to MDNS name requests.
|
||||
WiFiMDNSResponder mdnsResponder;
|
||||
|
||||
void setup() {
|
||||
//Initialize serial:
|
||||
Serial.begin(9600);
|
||||
|
||||
// check for the presence of the shield:
|
||||
if (WiFi.status() == WL_NO_SHIELD) {
|
||||
Serial.println("WiFi shield not present");
|
||||
// don't continue:
|
||||
while (true);
|
||||
}
|
||||
|
||||
// configure the LED pin for output mode
|
||||
pinMode(ledPin, OUTPUT);
|
||||
|
||||
// Start in provisioning mode:
|
||||
// 1) This will try to connect to a previously associated access point.
|
||||
// 2) If this fails, an access point named "wifi101-XXXX" will be created, where XXXX
|
||||
// is the last 4 digits of the boards MAC address. Once you are connected to the access point,
|
||||
// you can configure an SSID and password by visiting http://wifi101/
|
||||
WiFi.beginProvision();
|
||||
|
||||
while (WiFi.status() != WL_CONNECTED) {
|
||||
// wait while not connected
|
||||
|
||||
// blink the led to show an unconnected status
|
||||
digitalWrite(ledPin, HIGH);
|
||||
delay(500);
|
||||
digitalWrite(ledPin, LOW);
|
||||
delay(500);
|
||||
}
|
||||
|
||||
// connected, make the LED stay on
|
||||
digitalWrite(ledPin, HIGH);
|
||||
|
||||
server.begin();
|
||||
|
||||
// Setup the MDNS responder to listen to the configured name.
|
||||
// NOTE: You _must_ call this _after_ connecting to the WiFi network and
|
||||
// being assigned an IP address.
|
||||
if (!mdnsResponder.begin(mdnsName)) {
|
||||
Serial.println("Failed to start MDNS responder!");
|
||||
while(1);
|
||||
}
|
||||
|
||||
Serial.print("Server listening at http://");
|
||||
Serial.print(mdnsName);
|
||||
Serial.println(".local/");
|
||||
|
||||
// you're connected now, so print out the status:
|
||||
printWiFiStatus();
|
||||
}
|
||||
|
||||
|
||||
void loop() {
|
||||
// Call the update() function on the MDNS responder every loop iteration to
|
||||
// make sure it can detect and respond to name requests.
|
||||
mdnsResponder.poll();
|
||||
|
||||
// listen for incoming clients
|
||||
WiFiClient 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("<!DOCTYPE HTML>");
|
||||
client.println("<html>");
|
||||
// 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("<br />");
|
||||
}
|
||||
client.println("</html>");
|
||||
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");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void printWiFiStatus() {
|
||||
// print the SSID of the network you're attached to:
|
||||
Serial.print("SSID: ");
|
||||
Serial.println(WiFi.SSID());
|
||||
|
||||
// print your WiFi shield's IP address:
|
||||
IPAddress ip = WiFi.localIP();
|
||||
Serial.print("IP Address: ");
|
||||
Serial.println(ip);
|
||||
|
||||
// print the received signal strength:
|
||||
long rssi = WiFi.RSSI();
|
||||
Serial.print("signal strength (RSSI):");
|
||||
Serial.print(rssi);
|
||||
Serial.println(" dBm");
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user