ESP8266 ir Visuino: DHT11 temperatūros ir drėgmės žiniatinklio serveris: 12 žingsnių
ESP8266 ir Visuino: DHT11 temperatūros ir drėgmės žiniatinklio serveris: 12 žingsnių
Anonim
Image
Image

ESP8266 moduliai yra puikūs pigūs atskiri valdikliai su įmontuotu „Wi-Fi“, ir aš jau sukūriau apie juos daugybę instrukcijų.

DTH11/DTH21/DTH22 ir AM2301 yra labai populiarūs kombinuoti temperatūros ir drėgmės „Arduino“jutikliai, su jais taip pat sukūriau keletą instrukcijų, įskaitant „Instructable on Remote“termometrą ir drėgmės jutiklį su 2 ESP8266, prijungtais kartu prie savo privataus „Wi-Fi“tinklo.

Šioje instrukcijoje parodysiu, kaip galite sukurti temperatūros ir drėgmės žiniatinklio serverį naudodami ESP8266 ir DHT11 ir prisijungti prie jo esamame „Wi-Fi“tinkle iš kelių įrenginių su žiniatinklio naršykle.

1 žingsnis: komponentai

Prijunkite DHT11 prie „NodeMCU ESP8266“modulio
Prijunkite DHT11 prie „NodeMCU ESP8266“modulio
  1. „OneNodeMCU ESP8266“plokštė (naudojau „NodeMCU 0.9“versiją, bet bet kuri kita ar net atskira ESP-12 arba ESP-01 veiks)
  2. Vienas DHT11 jutiklio modulis, kurį gavau iš šio pigaus 37 jutiklių rinkinio
  3. 3 „Moteris-moteris“jungiamieji laidai

2 veiksmas: prijunkite DHT11 prie „NodeMCU ESP8266“modulio

Prijunkite DHT11 prie „NodeMCU ESP8266“modulio
Prijunkite DHT11 prie „NodeMCU ESP8266“modulio
Prijunkite DHT11 prie „NodeMCU ESP8266“modulio
Prijunkite DHT11 prie „NodeMCU ESP8266“modulio
Prijunkite DHT11 prie „NodeMCU ESP8266“modulio
Prijunkite DHT11 prie „NodeMCU ESP8266“modulio
  1. Prijunkite maitinimą (raudoną laidą), įžeminimą (juodas laidas) ir duomenis (pilka viela) prie DHT11 modulio (1 paveikslėlyje parodyta 2 skirtingų tipų DHT11 jutiklių moduliai. Kaip matote, kaiščiai gali skirtis, todėl atsargiai prijunkite!)
  2. Kitą įžeminimo laido galą (juodą laidą) prijunkite prie ESP8266 modulio įžeminimo kaiščio (2 pav.)
  3. Kitą maitinimo laido galą (raudoną laidą) prijunkite prie ESP8266 modulio 3,3 V maitinimo kaiščio (2 pav.)
  4. Kitą duomenų laido galą (pilką laidą) prijunkite prie ESP8266 modulio 2 skaitmeninio kaiščio (3 pav.)
  5. 4 paveikslėlyje parodyta, kur yra „NodeMCU 0.9“įžeminimas, 3,3 V maitinimas ir 2 skaitmeniniai kaiščiai

3 veiksmas: paleiskite „Visuino“ir pasirinkite ESP8266 plokštės tipą

Paleiskite „Visuino“ir pasirinkite ESP8266 plokštės tipą
Paleiskite „Visuino“ir pasirinkite ESP8266 plokštės tipą
Paleiskite „Visuino“ir pasirinkite ESP8266 plokštės tipą
Paleiskite „Visuino“ir pasirinkite ESP8266 plokštės tipą

Norėdami pradėti programuoti „Arduino“, turėsite įdiegti „Arduino IDE“iš čia:

Atminkite, kad „Arduino IDE 1.6.6“yra keletas svarbių klaidų

Įsitikinkite, kad įdiegėte 1.6.7 ar naujesnę versiją, kitaip ši instrukcija neveiks!

Jei to nepadarėte, atlikite šios instrukcijos veiksmus, kad nustatytumėte „Arduino IDE“programuoti ESP 8266

Taip pat reikia įdiegti „Visuino“:

  1. Pradėkite „Visuinoas“, parodytą pirmoje nuotraukoje
  2. Visuino „Arduino“komponente (1 pav.) Spustelėkite mygtuką „Įrankiai“
  3. Kai pasirodys dialogo langas, pasirinkite „NodeMCU ESP-12“, kaip parodyta 2 paveiksle

4 veiksmas: „Visuino“: nustatykite pagrindinio kompiuterio pavadinimą ir prieigos tašką

„Visuino“: nustatykite pagrindinio kompiuterio pavadinimą ir prieigos tašką
„Visuino“: nustatykite pagrindinio kompiuterio pavadinimą ir prieigos tašką
„Visuino“: nustatykite pagrindinio kompiuterio pavadinimą ir prieigos tašką
„Visuino“: nustatykite pagrindinio kompiuterio pavadinimą ir prieigos tašką
„Visuino“: nustatykite pagrindinio kompiuterio pavadinimą ir prieigos tašką
„Visuino“: nustatykite pagrindinio kompiuterio pavadinimą ir prieigos tašką
„Visuino“: nustatykite pagrindinio kompiuterio pavadinimą ir prieigos tašką
„Visuino“: nustatykite pagrindinio kompiuterio pavadinimą ir prieigos tašką

Pirmiausia turime sukonfigūruoti modulį prisijungti prie esamo prieigos taško ir priskirti jam „HostName“, kad galėtume jį atrasti tinkle.

  1. Objektų inspektoriuje išplėskite nuosavybę „Moduliai“, tada antrinę nuosavybę „WiFi“
  2. Objektų inspektoriuje nustatykite nuosavybės „HostName“vertę į „dht11server“(1 pav.)
  3. Objektų inspektoriuje išplėskite „WiFi“antrinę nuosavybę „AccessPoints“ir spustelėkite mygtuką „…“šalia jo vertės (2 pav.)
  4. „AccessPoins“redaktoriuje dešiniajame rodinyje pasirinkite „WiFi prieigos taškas“, tada kairėje spustelėkite mygtuką „+“, kad pridėtumėte prieigos tašką (2 pav.)
  5. Objektų inspektoriuje nustatykite nuosavybės „SSID“vertę į „Wi-Fi“viešosios interneto prieigos taško (prieigos taško) SSID (4 pav.)
  6. Jei jūsų „Wi-Fi“viešosios interneto prieigos taškui (prieigos taškui) reikia slaptažodžio, objekto tikrintojuje nustatykite slaptažodį, esantį ypatybės „Slaptažodis“vertėje (4 pav.)
  7. Uždarykite dialogo langą „AccessPoints“

5 veiksmas: „Visuino“: pridėkite TCP/IP serverio lizdą ryšiui

„Visuino“: pridėkite TCP/IP serverio lizdą ryšiui
„Visuino“: pridėkite TCP/IP serverio lizdą ryšiui
„Visuino“: pridėkite TCP/IP serverio lizdą ryšiui
„Visuino“: pridėkite TCP/IP serverio lizdą ryšiui
„Visuino“: pridėkite TCP/IP serverio lizdą ryšiui
„Visuino“: pridėkite TCP/IP serverio lizdą ryšiui

Toliau turime pridėti TCP/IP serverio lizdą bendravimui.

  1. Objektų inspektoriuje spustelėkite mygtuką „…“šalia „WiFi“antrinės nuosavybės „Sockets“vertės (1 pav.)
  2. „Sockets“redaktoriuje pasirinkite „TCP/IP Server“, tada spustelėkite mygtuką „+“(2 paveikslas), kad jį pridėtumėte (3 pav.)
  3. Uždarykite dialogo langą „Lizdai“

6 veiksmas: „Visuino“: pridėkite DTH11 ir suformatuotą teksto komponentą su 2 analoginiais kanalais

„Visuino“: pridėkite DTH11 ir suformatuotą teksto komponentą su 2 analoginiais kanalais
„Visuino“: pridėkite DTH11 ir suformatuotą teksto komponentą su 2 analoginiais kanalais
„Visuino“: pridėkite DTH11 ir suformatuotą teksto komponentą su 2 analoginiais kanalais
„Visuino“: pridėkite DTH11 ir suformatuotą teksto komponentą su 2 analoginiais kanalais
„Visuino“: pridėkite DTH11 ir suformatuotą teksto komponentą su 2 analoginiais kanalais
„Visuino“: pridėkite DTH11 ir suformatuotą teksto komponentą su 2 analoginiais kanalais

Norėdami valdyti ir skaityti temperatūrą ir drėgmę iš DHT11, turime pridėti komponentą „Visuino“.

Mes taip pat turime sukurti tinklalapį iš duomenų. Puslapis yra tik HTML tekstinis dokumentas, todėl jį generuoti galime naudoti suformatuoto teksto komponentą.

  1. Komponentų įrankių rinkinio filtro laukelyje įveskite „dht“, tada pasirinkite komponentą „Drėgmė ir termometras DHT11/21/22/AM2301“(1 pav.) Ir nuleiskite jį į projektavimo sritį
  2. Komponentų įrankių rinkinio laukelyje Filtras įveskite „forma“, tada pasirinkite komponentą „Formatuotas tekstas“(2 pav.) Ir nuleiskite jį į dizaino sritį
  3. Spustelėkite „FormattedText1“komponento mygtuką „Įrankiai“(3 pav.)
  4. Elemento redaktoriuje pasirinkite analoginį elementą dešinėje ir du kartus spustelėkite mygtuką „+“kairėje (4 pav.), Kad pridėtumėte 2 iš jų (5 paveikslas)
  5. Uždarykite „Elementų“redaktorių

7 veiksmas: „Visuino“: nustatykite suformatuotą tekstą serverio atsakymui

„Visuino“: nustatykite suformatuotą tekstą serverio atsakymui
„Visuino“: nustatykite suformatuotą tekstą serverio atsakymui
„Visuino“: nustatykite suformatuotą tekstą serverio atsakymui
„Visuino“: nustatykite suformatuotą tekstą serverio atsakymui

Turime nurodyti HTML tekstą, kuris bus sugeneruotas, kai žiniatinklio klientas prisijungs prie serverio.

Nurodysime, kad ryšys būtų uždarytas po mano išsiųstų duomenų, taip pat nurodysime naršyklei po 5 sekundžių vėl prisijungti (atnaujinti), pridedant prie dokumento „Atnaujinti: 5“. Tokiu būdu tinklalapis bus atnaujinamas kas 5 sekundes.

  1. Dizaino srityje pasirinkite komponentą FormattedText1 (1 paveikslas)
  2. Objektų inspektoriuje pasirinkite ypatybę „Tekstas“ir spustelėkite mygtuką „…“šalia jo vertės (1 pav.)
  3. „Teksto“redaktoriuje įveskite: „HTTP/1.1 200 OK“„Turinio tipas: tekstas/html“„Ryšys: uždaryti“„Atnaujinti: 5“„“„"""""" Temperatūra: %0 "" Drėgmė: %1 "" "" "(2 pav.) %0 bus pakeista verte iš AnalogElement1, o %1 bus pakeista verte iš AnalogElement2
  4. Spustelėkite mygtuką Gerai, kad uždarytumėte dialogo langą

8 veiksmas: „Visuino“: prijunkite DHT11 komponentą

„Visuino“: prijunkite DHT11 komponentą
„Visuino“: prijunkite DHT11 komponentą
„Visuino“: prijunkite DHT11 komponentą
„Visuino“: prijunkite DHT11 komponentą
„Visuino“: prijunkite DHT11 komponentą
„Visuino“: prijunkite DHT11 komponentą
  1. Prijunkite „HumidityThermometer1“komponento „Temperatūros“išvesties kaištį prie „FormattedText1“komponento „AnalogElement1“kaiščio „In“(1 pav.)
  2. Prijunkite „HumidityThermometer1“komponento „Humidity“išvesties kaištį prie „FormattedText1“komponento „AnalogElement2“kaiščio „In“(2 pav.)
  3. Prijunkite „HumidityThermometer1“komponento „jutiklio“kaištį prie „Arduino“komponento „Digital [2]“kanalo „Digital“įvesties kaiščio (3 pav.)

9 veiksmas: „Visuino“: pridėkite ir prijunkite krašto aptikimo komponentą

„Visuino“: pridėkite ir prijunkite krašto aptikimo komponentą
„Visuino“: pridėkite ir prijunkite krašto aptikimo komponentą
„Visuino“: pridėkite ir prijunkite krašto aptikimo komponentą
„Visuino“: pridėkite ir prijunkite krašto aptikimo komponentą
„Visuino“: pridėkite ir prijunkite krašto aptikimo komponentą
„Visuino“: pridėkite ir prijunkite krašto aptikimo komponentą
„Visuino“: pridėkite ir prijunkite krašto aptikimo komponentą
„Visuino“: pridėkite ir prijunkite krašto aptikimo komponentą

Turime siųsti HTML tekstą kiekvieną kartą, kai atsiranda naujas ryšys. Prieš siųsdami turime šiek tiek palaukti, nes žiniatinklio naršyklės turi nusiųsti užklausą, kol tikisi pamatyti rezultatą. Norėdami tai padaryti, naudosime „Delay“komponentą, prijungtą prie TCP/IP serverio lizdo „Prijungtas“kaiščio.

  1. Komponentų įrankių rinkinio laukelyje Filtras įveskite „delay“, tada pasirinkite „Delay“komponentą (1 pav.) Ir nuleiskite jį į projektavimo sritį
  2. Ypatybėse nustatykite ypatybės „Interval (uS)“vertę į 200000 (2 pav.)
  3. Prijunkite „NodeMCU ESP-12“komponento „Modules. WiFi. Sockets. TCPServer1“kaištį „Prijungtas“prie „Delay1“komponento kaiščio „In“(3 pav.)
  4. Prijunkite „Delay1“komponento „Out“kaištį prie „FormattedText1“komponento „Clock“įvesties kaiščio (4 pav.)

10 veiksmas: „Visuino“: prijunkite formatuotą teksto komponentą ir pridėkite bei prijunkite atidėjimo komponentą

„Visuino“: prijunkite suformatuotą teksto komponentą ir „Add and Connect Delay Component“
„Visuino“: prijunkite suformatuotą teksto komponentą ir „Add and Connect Delay Component“
„Visuino“: prijunkite suformatuotą teksto komponentą ir „Add and Connect Delay Component“
„Visuino“: prijunkite suformatuotą teksto komponentą ir „Add and Connect Delay Component“
„Visuino“: prijunkite suformatuotą teksto komponentą ir „Add and Connect Delay Component“
„Visuino“: prijunkite suformatuotą teksto komponentą ir „Add and Connect Delay Component“
„Visuino“: prijunkite suformatuotą teksto komponentą ir „Add and Connect Delay Component“
„Visuino“: prijunkite suformatuotą teksto komponentą ir „Add and Connect Delay Component“
  1. Prijunkite FormattedText1 komponento „Out“kaištį prie „NodeMCU ESP-12“komponento „Modules. WiFi. Sockets. TCPServer1“kaiščio „In“(1 pav.)
  2. Komponentų įrankių rinkinio laukelyje Filtras įveskite „delay“, tada pasirinkite „Delay“komponentą (2 pav.) Ir nuleiskite jį į projektavimo sritį
  3. Prijunkite „FormattedText1“komponento „Out“kaištį prie „Delay2“komponento „In“kaiščio (3 pav.)
  4. Prijunkite „Delay2“komponento „Out“kaištį prie „NodeMCU ESP-12“komponento „Modules. WiFi. Sockets. TCPServer1“įvesties kaiščio „Disconnect“(4 pav.)

„Delay“komponentas netrukus po teksto išsiuntimo atjungs lizdą.

11 veiksmas: sukurkite, sukompiliuokite ir įkelkite „Arduino“kodą

Sukurkite, sudarykite ir įkelkite „Arduino“kodą
Sukurkite, sudarykite ir įkelkite „Arduino“kodą
Sukurkite, sudarykite ir įkelkite „Arduino“kodą
Sukurkite, sudarykite ir įkelkite „Arduino“kodą
  1. „Visuino“paspauskite F9 arba spustelėkite mygtuką, parodytą 1 paveikslėlyje, kad sugeneruotumėte „Arduino“kodą, ir atidarykite „Arduino IDE“
  2. Prijunkite „NodeMCU“modulį USB kabeliu prie kompiuterio
  3. Pasirinkite plokštės tipą ir nuoseklųjį prievadą, kaip aš jums parodžiau šioje instrukcijoje
  4. „Arduino IDE“spustelėkite mygtuką Įkelti, kad surinktumėte ir įkeltumėte kodą (2 pav.)

12 žingsnis: ir žaisti …

Image
Image
Ir žaisti…
Ir žaisti…

Sveikinu! Sukūrėte „Wi-Fi“temperatūros ir drėgmės žiniatinklio serverį.

1 paveikslėlyje ir vaizdo įraše galite pamatyti prijungtą ir įjungtą projektą. Moduliui maitinti naudojau nedidelį USB maitinimo bloką.

Įsitikinkite, kad 4 veiksmo projekte įvedėte teisingą „Wi-Fi“viešosios interneto prieigos taško SSID ir slaptažodį

Jei kompiuteryje ar mobiliajame įrenginyje atidarote žiniatinklio naršyklę ir įvedate:

dht11server./

Ir paspauskite „Enter“, pamatysite modulio išmatuotą temperatūrą ir drėgmę. Skaitymas atnaujinamas kas 5 sekundes, kaip nurodyta 7 veiksme.

Būtinai pridėkite tašką vardo pabaigoje, kitaip „Windows“negalės išspręsti domeno vardo

2 paveiksle galite pamatyti visą Visuino diagramą.

Taip pat pridedamas „Visuino“projektas, kurį sukūriau šiam „Instructable“. Galite atsisiųsti ir atidaryti „Visuino“: