Internettkontrollert LED ved bruk av ESP32 -basert webserver: 10 trinn
Internettkontrollert LED ved bruk av ESP32 -basert webserver: 10 trinn
Anonim
Internettkontrollert LED ved bruk av ESP32 -basert webserver
Internettkontrollert LED ved bruk av ESP32 -basert webserver

Prosjekt oversikt

I dette eksemplet vil vi finne ut hvordan du lager en ESP32-basert webserver for å kontrollere LED-tilstand, som er tilgjengelig fra hvor som helst i verden. Du trenger en Mac-datamaskin for dette prosjektet, men du kan kjøre denne programvaren til og med på en billig og lite strømdatamaskin som Raspberry Pi.

Utarbeidelse av ESP32 med Arduino IDE

For å begynne å programmere ESP32 ved hjelp av Arduino IDE og Arduino programmeringsspråk, trenger du et spesielt tillegg. Les om hvordan du forbereder Arduino IDE for ESP32 på Mac OS ved hjelp av følgende lenke.

Rekvisita

For denne opplæringen trenger du følgende elementer:

  • ESP32 utviklingsbord 5 mm
  • LED -motstand 220ohm
  • 16x2 LCD -skjerm med I2C -modul
  • Brødbrett
  • Jumper ledninger
  • Micro USB -kabel

Trinn 1: Bygg kretsen

Bygg kretsen
Bygg kretsen

Utfør tilkoblinger som vist i følgende skjematiske diagram nedenfor

Start med å koble 3V3 forsyningsspenning ut på ESP32 og GNDto brødbrettet. Koble LED via motstand til ESP32 ved hjelp av GPIO pin 23 som digital utgangsstift. Deretter kobler du SDA -pinnen på 16x2 LCD -skjerm til GPIO -pinne 21 og SCL til GPIO -pinne 22.

Trinn 2: Rask oversikt over SPIFFS filsystem

SPIFFS står for "Serial Peripheral Interface Flash File System", dvs. filsystem for flash -minne som overfører data gjennom SPI. Følgelig er SPIFFS et forenklet filsystem designet for mikrokontrollere med flash -brikker som overfører data via SPI -bussen (for eksempel ESP32 flash -minne).

SPIFFS er mest nyttig for bruk med ESP32 i følgende situasjoner:

  • Opprette filer for lagring av innstillinger
  • Permanent datalagring.
  • Opprette filer for å lagre en liten mengde data (i stedet for å bruke et microSD -kort for dette).
  • Lagre HTML- og CSS -filer for å lage en webserver.

Trinn 3: Installasjon av SPIFFS Bootloader på Mac OS

Installasjon av SPIFFS Bootloader på Mac OS
Installasjon av SPIFFS Bootloader på Mac OS

Du kan opprette, lagre og skrive data til filer som er lagret i ESP32 -filsystemet direkte ved å bruke plugin på Arduino IDE.

Først og fremst må du kontrollere at du har den nyeste versjonen av Arduino IDE installert, og deretter gjøre følgende:

  • Åpne følgende lenke og last ned arkivet "ESP32FS-1.0.zip"
  • Gå til Arduino IDE -katalogen, som ligger i Dokumenter -mappen.
  • Opprett en verktøymappe hvis den ikke finnes. Lag en ny mappe ESP32FS inne i verktøykatalogen. Inne i ESP32FS lager du en til, som kalles verktøy.
  • Pakk ut ZIP -arkivet som ble lastet ned i trinn 1 til verktøymappen.
  • Start Arduino IDE på nytt.
  • For å sjekke om programtillegget ble installert, åpner du Arduino IDE og klikker på "Verktøy" og sjekker om det er et element "ESP32 Sketch Data Upload" i denne menyen.

Trinn 4: Installere biblioteker

Med ESPAsyncWebServer og AsyncTCP -biblioteker kan du opprette en webserver ved hjelp av filer fra filsystemet til ESP32. For mer informasjon om disse bibliotekene, sjekk følgende lenke.

Installer ESPAsyncWebServer -biblioteket

  • Klikk her for å laste ned ZIP -arkivet til biblioteket.
  • Pakk ut dette arkivet. Du bør få mappen ESPAsyncWebServer-master.
  • Gi nytt navn til "ESPAsyncWebServer".

Installer AsyncTCP -biblioteket

  • Klikk her for å laste ned ZIP -arkivet til biblioteket.
  • Pakk ut dette arkivet. Du bør få AsyncTCP-master-mappen.
  • Gi den nytt navn til "AsyncTCP".

Flytt mappene ESPAsyncWebServer og AsyncTCP til biblioteker -mappen, som ligger inne i Dokument -katalogen.

Til slutt, start Arduino IDE på nytt.

Trinn 5: Lag en Index.html- og Style.css -fil med følgende innhold

HTML/CSS -mal for veksleknapp ble hentet fra følgende kilde.

Trinn 6: Arduino -kode

Koden var hovedsakelig basert på Arduino -koden som ble hentet fra ESP32 Web Server ved bruk av SPIFFS og How to Use I2C LCD with ESP32 on Arduino IDE.

Trinn 7: Last opp Arduino -koden og filene ved hjelp av SPIFFS Loader

  • Åpne skissemappen til Arduino -koden.
  • Opprett en ny mappe som heter “data” i denne mappen.
  • I datamappen må du sette index.html og style.css.
  • Last opp Arduino -kode
  • Klikk deretter på Arduino IDE på Verktøy> ESP32 Sketch Data Upload for å laste opp filene

Trinn 8: Bestem ESP32 -webserverens IP -adresse

Bestem ESP32 -webserverens IP -adresse
Bestem ESP32 -webserverens IP -adresse

Det kan finnes på to måter.

  • Seriell skjerm på Arduino IDE (Verktøy> Seriell skjerm)
  • På LCD -skjerm

Trinn 9: Testing av den lokale webserveren

Test av den lokale webserveren
Test av den lokale webserveren

Deretter åpner du en nettleser du ønsker, og limer inn følgende IP -adresse i adressefeltet. Du bør få en utgang som ligner på skjermbildet nedenfor.

Trinn 10: Tilgang til en lokal webserver hvor som helst i verden ved hjelp av Ngrok

Tilgang til en lokal webserver fra hvor som helst i verden ved hjelp av Ngrok
Tilgang til en lokal webserver fra hvor som helst i verden ved hjelp av Ngrok

Ngrok er en plattform som lar deg organisere ekstern tilgang til en webserver eller en annen tjeneste som kjører på PC -en din fra eksternt internett. Tilgang organiseres gjennom den sikre tunnelen som ble opprettet ved starten av ngrok.

  • Følg denne lenken og meld deg på.
  • Etter at du har opprettet en konto, logger du på og går til kategorien "Auth". Kopier linjen fra feltet "Din Tunnel Authtoken".
  • Klikk på "Last ned" -fanen i navigasjonsfeltet. Velg versjonen av ngrok som matcher operativsystemet og last den ned.
  • Pakk ut den nedlastede mappen og kjør kommandolinjen.
  • Koble til kontoen din ved å skrive inn følgende kommando

./ngrok authtoken

Start en HTTP -tunnel på port 80

./ngrok http Your_IP_Address: 80

Hvis alt ble gjort riktig, bør tunnelstatusen endres til "online", og en omdirigeringskobling skal vises i "Videresending" -kolonnen. Ved å skrive inn denne lenken i nettleseren din, kan du få tilgang til webserveren fra hvor som helst i verden.

Anbefalt: