// import des librairies #include <ESP8266WiFi.h> #include <ESP8266WebServer.h> #include "DHT.h" // https://github.com/adafruit/DHT-sensor-library // Dé-commentez la ligne qui correspond à votre capteur //#define DHTTYPE DHT11 // DHT 11 //#define DHTTYPE DHT21 // DHT 21 (AM2301) #define DHTTYPE DHT22 // DHT 22 (AM2302), AM2321 // Changer vos SSID et Password const char* ssid = "xxxxx"; const char* password = "yyyyy"; // on declare un serveur nommé "serveur" accessible sur le port 80 ESP8266WebServer serveur(80); // on defini le pin sur lequel est branché la sonde uint8_t DHTPin = 4; // D2 --> GPIO4 // on configure la sonde DHT. DHT dht(DHTPin, DHTTYPE); // on definit 2 variables de type float pour stocker nos datas float Temperature; float Humidity; // le setup void setup() { Serial.begin(115200); // On demarre la com serie Serial.println(""); Serial.println(""); pinMode(DHTPin, INPUT); // On défini le GPIO utilisé par la sonde en entrée dht.begin(); // On initialise la sonde Serial.print("Connexion à "); // On précise sur la com série qu'on va se connecter Serial.println(ssid); // Au ssid WiFi.begin(ssid, password); // On se connecte au Wifi while (WiFi.status() != WL_CONNECTED) { // Tant qu'on est pas connecté on écrit un point toutes les secondes delay(1000); Serial.print("."); } Serial.println(""); Serial.println(""); Serial.print("WiFi connecté, IP : "); // On précise dans la com série qu'on est connecté Serial.println(WiFi.localIP()); // On affiche l'ip dans la com série Serial.println(""); serveur.on("/", handle_OnConnect); // On défini la fonction a lancer sur la page d'accueil du site web serveur.onNotFound(handle_NotFound); // On défini la fonction a lancer sur une page non trouvée serveur.begin(); // On démarre le serveur web Serial.println("Serveur HTTP démarré"); // On précise dans la com série que le serveur a démarré } // la boucle void loop() { serveur.handleClient(); // écoute en boucle sur le serveur si on a un client } // la fonction qui envoie la page d'accueil au serveur void handle_OnConnect() { Temperature = dht.readTemperature(); // Lecture de la température en Celcius Humidity = dht.readHumidity(); // Lecture du taux d'humidité serveur.send(200, "text/html", SendHTML(Temperature,Humidity)); // on envoie au serveur notre page web " la fonction SendHTML avec nos datas" } // la fonction qui envoie la page d'erreur void handle_NotFound(){ serveur.send(404, "text/plain", "Not found"); } // la fonction qui construit notre page web avec nos datas // nos datas seront mise à jour par ajax sur la page web String SendHTML(float Temperaturestat,float Humiditystat){ String ptr = "<!DOCTYPE html>\n"; ptr +="<head><meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0, user-scalable=no\">\n"; ptr +="<title>NodeMCU DHT22</title>\n"; ptr +="<style>html { font-family: Helvetica; display: inline-block; margin: 0px auto; text-align: center;}\n"; ptr +="body{margin-top: 50px;} h1 {color: #444444;margin: 50px auto 30px;}\n"; ptr +="p {font-size: 24px;color: #444444;margin-bottom: 10px;}\n"; ptr +="</style>\n"; ptr +="<script>\n"; ptr +="setInterval(loadDoc,200);\n"; ptr +="function loadDoc() {\n"; ptr +="var xhttp = new XMLHttpRequest();\n"; ptr +="xhttp.onreadystatechange = function() {\n"; ptr +="if (this.readyState == 4 && this.status == 200) {\n"; ptr +="document.getElementById(\"webpage\").innerHTML =this.responseText}\n"; ptr +="};\n"; ptr +="xhttp.open(\"GET\", \"/\", true);\n"; ptr +="xhttp.send();\n"; ptr +="}\n"; ptr +="</script>\n"; ptr +="</head>\n"; ptr +="<body>\n"; ptr +="<div id=\"webpage\">\n"; ptr +="<h1>NodeMCU DHT22</h1>\n"; ptr +="<p>Temperature: "; ptr +=Temperaturestat; ptr +="°C</p>"; ptr +="<p>Humidity: "; ptr +=Humiditystat; ptr +="%</p>"; ptr +="</div>\n"; ptr +="</body>\n"; ptr +="</html>\n"; return ptr; }