domingo, 28 de abril de 2019

Enviando Dados para o WebServices

Fala ai pessoal, beleza?

Nesse post vou mostrar como enviar os dados do DHT11 usando o WebServices.

Para começar é necessário ter a biblioteca do DHT11 e do Adafruit (Se der uma olhada nas postagens antigas eu mostro como instalar essas bibliotecas)

Após colocar essas bibliotecas, adicione esse código no ESP32:

#include <WiFi.h>
#include <WebServer.h>
#include "DHT.h"

// TIPOS DE DHT QUE É POSSÍVEL USAR
#define DHTTYPE DHT11   // DHT 11
//#define DHTTYPE DHT21   // DHT 21 (AM2301)
//#define DHTTYPE DHT22   // DHT 22  (AM2302), AM2321

/*Put your SSID & Password*/
const char* ssid = "NOME DA SUA REDE"; 

const char* password = "SENHA DA SUA REDE";
WebServer server(80);

// PINO DO SENSOR
uint8_t DHTPin = 23;
              
DHT dht(DHTPin, DHTTYPE);               

float Temperature;
float Humidity;

void setup() {
  Serial.begin(115200);
  delay(100);
 
  pinMode(DHTPin, INPUT);

  dht.begin();             

  Serial.println("Connecting to ");
  Serial.println(ssid);

  //connect to your local wi-fi network
  WiFi.begin(ssid, password);

  //check wi-fi is connected to wi-fi network
  while (WiFi.status() != WL_CONNECTED) {
  delay(1000);
  Serial.print(".");
  }
  Serial.println("");
  Serial.println("WiFi connected..!");
  Serial.print("Got IP: ");  Serial.println(WiFi.localIP());

  server.on("/", handle_OnConnect);
  server.onNotFound(handle_NotFound);

  server.begin();
  Serial.println("HTTP server started");

}
void loop() {
 
  server.handleClient();
 
}

void handle_OnConnect() {

 Temperature = dht.readTemperature(); // Gets the values of the temperature
  Humidity = dht.readHumidity(); // Gets the values of the humidity
  server.send(200, "text/html", SendHTML(Temperature,Humidity));
}

void handle_NotFound(){
  server.send(404, "text/plain", "Not found");
}


//CONFIGURAÇÃO DA PÁGINA
String SendHTML(float Temperaturestat,float Humiditystat){
  String ptr = "<!DOCTYPE html> <html>\n";
  ptr +="<head><meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0, user-scalable=no\">\n";
  ptr +="<title>ESP32 Weather Report</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 +="</head>\n";
  ptr +="<body>\n";
  ptr +="<div id=\"webpage\">\n";
  ptr +="<h1>ESP32 Weather Report</h1>\n";
  ptr +="<p>Temperature: ";
  ptr +=(int)Temperaturestat;
  ptr +="°C</p>";
  ptr +="<p>Humidity: ";
  ptr +=(int)Humiditystat;
  ptr +="%</p>";
  ptr +="</div>\n";
  ptr +="</body>\n";
  ptr +="</html>\n";
  return ptr;
}


Ao compilar esse código, abra o monitor serial e ele retornará o IP, digite esse IP em algum navegador e pronto aparecerá os dados na página.


* No código, é possível alterar configurações de layout da sua página.

É possível também acrescentar um refresh na página para atualizar os dados:

ptr +="<meta http-equiv=refresh content=TEMPO EM SEGUNDOS, http:ENDEREÇO DE RETORNO>\n";

** Se você assoprar no seu sensor e atualizar a página, a umidade aumentará, o que confirma que o código está funcionando  .

Nenhum comentário:

Postar um comentário