Obsah:
- Predpoklady
- Krok 1: Začnite s jednoduchým náčrtom webového servera
- Krok 2: Vytvorenie vzdialeného JavaScriptu
- Krok 3: Načítanie vzdialeného súboru JavaScript do prehliadača návštevníkov
- Krok 4: Pridanie nových prvkov na stránku
- Krok 5: Interaktívne prvky
- Krok 6: Reagujte na interaktívny prvok
- Krok 7: Záver
2025 Autor: John Day | [email protected]. Naposledy zmenené: 2025-01-23 15:06
Pri vytváraní projektu Arduino / ESP (ESP8266 / ESP32) ste mohli jednoducho naprogramovať všetko. Ale častejšie sa niečo stane a skončíte tak, že svoje zariadenie IoT znova pripojíte k svojmu IDE. Alebo ste práve získali viac ľudí prístup ku konfigurácii a chcete poskytnúť používateľské rozhranie namiesto toho, aby ste od nich očakávali, že porozumejú vnútornému fungovaniu.
Tento návod vám povie, ako umiestniť väčšinu používateľského rozhrania do cloudu namiesto na Arduino / ESP. Takto to ušetrí miesto a pamäť. Služba poskytujúca bezplatné statické webové stránky je obzvlášť vhodná ako „cloud“, napríklad stránky GitHub, ale pravdepodobne budú fungovať aj ďalšie možnosti.
Vytvorenie webovej stránky týmto spôsobom vyžaduje, aby prehliadač používateľa prešiel 4 krokmi:
- Vyžiadajte si koreňovú adresu URL z Arduino / ESP
- Získajte veľmi jednoduchú webovú stránku, ktorá hovorí:
- Vyžiadajte si súbor JavaScript z cloudu
- Dostanete kód, ktorý vytvára skutočnú stránku
Tento návod tiež vysvetľuje, ako interagovať s Arduino / ESP, akonáhle je stránka pripravená, podľa vyššie uvedených krokov.
Kód vytvorený v tomto návode je možné nájsť aj na GitHub.
Predpoklady
Tento návod predpokladá, že ste získali prístup k určitým materiálom a niektorým predchádzajúcim znalostiam:
- Arduino (so sieťovým prístupom) / ESP
- Počítač, ku ktorému je potrebné pripojiť vyššie uvedené
- WiFi pripojenie pripojené na internet
- Nainštalované IDE Arduino (aj pre ESP32)
- Viete, ako nahrať skicu do svojho zariadenia IoT
- Viete, ako používať Git & GitHub
Krok 1: Začnite s jednoduchým náčrtom webového servera
Začneme čo najjednoduchšie a necháme to odteraz rásť.
#zahrnúť
const char* ssid = "yourssid"; const char* heslo = "yourpasswd"; Server WiFiServer (80); void setup () {// Inicializácia sériového čísla a čakanie na otvorenie portu: Serial.begin (115200); while (! Serial) {; // počkajte na pripojenie sériového portu. Potrebné iba pre natívny port USB} WiFi.begin (ssid, heslo); while (WiFi.status ()! = WL_CONNECTED) {oneskorenie (500); Serial.print ("."); } Serial.println („Pripojené WiFi.“); Serial.println ("IP adresa:"); Serial.println (WiFi.localIP ()); server.begin (); } void loop () {// počúvanie prichádzajúcich klientov WiFiClient client = server.available (); // počúvať prichádzajúcich klientov bool sendResponse = false; // nastavená na true, ak chceme odoslať odpoveď String urlLine = ""; // vytvorte reťazec na uchovanie požadovanej adresy URL, ak (klient) // ak získate klienta, {Serial.println ("nový klient."); // vytlačenie správy zo sériového portu String currentLine = ""; // vytvorte reťazec na uchovávanie prichádzajúcich údajov od klienta while (client.connected ()) // slučka, zatiaľ čo klient je pripojený {if (client.available ()) // ak existujú bajty na čítanie z klienta, {char c = client.read (); // prečítajte bajt, potom ak (c == '\ n') // ak je bajt znakom nového riadka {// ak je aktuálny riadok prázdny, dostanete dva znaky nového riadka za sebou. // tým sa požiadavka HTTP klienta končí, preto pošlite odpoveď: if (currentLine.length () == 0) {sendResponse = true; // všetko je v poriadku! prestávka; // vybočte z cyklu while} else // ak máte nový riadok, vymažte currentLine: {if (currentLine.indexOf ("GET /")> = 0) // toto by mal byť riadok adresy URL {urlLine = currentLine; // uložte ho na neskoršie použitie} currentLine = ""; // vynulovanie reťazca currentLine}} else if (c! = '\ r') // ak máte niečo iné ako znak návratu vozíka, {currentLine += c; // pridajte ho na koniec currentLine}}} if (sendResponse) {Serial.print ("Client requested"); Serial.println (urlLine); // Hlavičky HTTP vždy začínajú kódom odpovede (napr. HTTP/1,1 200 OK) // a typom obsahu, aby klient vedel, čo príde, potom prázdnym riadkom: client.println („HTTP/1,1 200 OK“); client.println ("Typ obsahu: text/html"); client.println (); if (urlLine.indexOf ("GET /")> = 0) // ak je adresa URL iba " /" {// obsah odpovede HTTP nasleduje za hlavičkou: client.println ("Hello world!"); } // Odpoveď HTTP sa končí ďalším prázdnym riadkom: client.println (); } // zavrieť spojenie: client.stop (); Serial.println („Klient odpojený.“); }}
Skopírujte vyššie uvedený kód alebo si ho stiahnite z potvrdenia na GitHub.
Nezabudnite zmeniť SSID a heslo tak, aby zodpovedali vašej sieti.
Táto skica používa dobre známe Arduino
nastaviť()
a
slučka ()
funkcie. V
nastaviť()
Funkcia inicializuje sériové pripojenie k IDE a WiFi. Akonáhle je WiFi pripojené k uvedenému SSID, vytlačí sa IP a spustí sa webový server. V každej iterácii súboru
slučka ()
funkcia webového servera sa kontroluje pre pripojených klientov. Ak je klient pripojený, požiadavka sa prečíta a požadovaná adresa URL sa uloží do premennej. Ak je všetko v poriadku, odpoveď servera klientovi sa vykoná na základe požadovanej adresy URL.
VÝSTRAHA! Tento kód používa na zjednodušenie triedu Arduino String. Optimalizácia reťazcov nespadá do rozsahu tohto pokynu. Prečítajte si viac o tomto v návode na tému Manipulácia so strunami Arduino pomocou minimálneho RAM.
Krok 2: Vytvorenie vzdialeného JavaScriptu
Arduino / ESP povie prehliadaču návštevníkov, aby načítal tento jeden súbor. Všetko ostatné vykoná tento kód JavaScript.
V tomto návode použijeme jQuery, nie je to úplne nevyhnutné, ale veci uľahčí.
Tento súbor musí byť prístupný z webu, na to, aby to fungovalo, stačí server so statickými stránkami, napríklad stránky GitHub. Pravdepodobne budete chcieť vytvoriť nové úložisko GitHub a vytvoriť súbor
gh-stránok
pobočka. Vložte nasledujúci kód do súboru a
.js
súbor v úložisku v správnej vetve.
var cdnjsURL = 'https://cdnjs.cloudflare.com/ajax/libs/', $; (function () {var script = document.createElement ('script'); // create a element script.src = cdnjsURL + 'jquery/3.2.1/jquery.min.js'; // set the src = "" atribút script.onload = function () // funkcia spätného volania, volá sa po načítaní súboru jquery {$ = window.jQuery; // sprístupní jQuery ako globálnu premennú $ init (); // zavolá funkciu init}; dokument. getElementsByTagName ('head') [0].appendChild (skript); // pridanie vytvorenej značky do dokumentu, spustí sa načítanie súboru jQuery lib}) (); function init () {// Dokončenie načítania jQuery, pridá sem kód neskôr …}
Skopírujte vyššie uvedený kód alebo si ho stiahnite z potvrdenia na GitHub.
Skontrolujte, či je váš súbor prístupný. V prípade stránok GitHub navštívte https://username.github.io/repository/your-file.j… (nahraďte
používateľské meno
,
Úložisko
a
your-file.js
pre správne parametre).
Krok 3: Načítanie vzdialeného súboru JavaScript do prehliadača návštevníkov
Teraz, keď máme všetko nastavené, je načase nechať webovú stránku načítať vzdialený súbor JavaScript.
Môžete to urobiť zmenou riadku 88 náčrtu z
client.println („Hello world!“); t
client.println ("");
(zmeniť
src
atribút smerujúci k vášmu vlastnému súboru JavaScript). Toto je malá html webová stránka, stačí, ak načítate súbor JavaScript do prehliadača návštevníkov.
Zmenený súbor nájdete aj v zodpovedajúcom potvrdení na GitHub.
Nahrajte upravenú skicu do svojho Arduino / ESP.
Krok 4: Pridanie nových prvkov na stránku
Prázdna stránka je k ničomu, preto je načase pridať na webovú stránku nový prvok. Zatiaľ to bude video YouTube. V tomto prípade sa na dosiahnutie tohto cieľa použijú niektoré kódy jQuery.
Pridajte nasledujúci riadok kódu do súboru
init ()
funkcia:
$ (''). prop ({src: 'https://www.youtube.com/embed/k12h_FOInZg?rel=0', frameborder: '0'}). css ({šírka: '608px', výška: '342px'}). AppendTo ('body');
Tým sa vytvorí súbor
iframe
prvok, nastavte správny
src
priradiť a nastaviť veľkosť pomocou css a pridať prvok do tela stránky.
jQuery nám pomáha ľahko vyberať a meniť prvky na webovej stránke. Je potrebné vedieť niekoľko základných vecí:
-
$ ('body')
- vyberie akýkoľvek už existujúci prvok, je možné použiť aj iné selektory css
-
$(' ')
vytvára nový
- prvok (ale nepridá ho do dokumentu)
-
.appendTo ('. main')
- pripojí vybraný/vytvorený prvok k prvku s triedou css „main“
-
Ďalšie funkcie na pridanie prvkov sú
.append ()
,
.prepend ()
,
.prependTo ()
,
. vložiť ()
,
.insertAfter ()
,
.insertBefore ()
,
.po ()
,
.pred ()
Ak je niečo nejasné, pozrite sa na zodpovedajúci záväzok na GitHub.
Krok 5: Interaktívne prvky
Video je zábavné, ale účelom tohto návodu je interakcia s Arduino / ESP. Nahraďme video za tlačidlo, ktoré odosiela informácie do Arduino / ESP a tiež čaká na odpoveď.
Budeme potrebovať a
$('')
pridať na stránku a pripojiť k nej poslucháča udalostí. Eventlistener zavolá funkciu spätného volania, keď dôjde k uvedenej udalosti:
$ (''). text ('tlačidlo'). na ('klik', funkcia ()
{// kód tu sa spustí po kliknutí na tlačidlo}). appendTo ('body');
A pridajte funkciu AJAX do funkcie spätného volania:
$.get ('/ajax', funkcia (údaje)
{// kód tu bude vykonaný po dokončení požiadavky AJAX});
Akonáhle je žiadosť dokončená, vrátené údaje budú pridané na stránku:
$('
').text (údaje).appendTo (' telo ');
Stručne povedané, vyššie uvedený kód vytvorí tlačidlo, pridá ho na webovú stránku, po kliknutí na tlačidlo sa odošle žiadosť a na webovú stránku sa pridá aj odpoveď.
Ak používate spätné volania prvýkrát, možno budete chcieť skontrolovať potvrdenie na serveri GitHub a zistiť, ako je všetko vnorené.
Krok 6: Reagujte na interaktívny prvok
Na požiadavku AJAX je samozrejme potrebná odpoveď.
Ak chcete vytvoriť správnu odpoveď pre súbor
/ajax
URL budeme musieť pridať
ináč Ak()
hneď za záverečnou zátvorkou príkazu if, ktorý kontroluje
/
url.
else if (urlLine.indexOf ("GET /ajax")> = 0)
{client.print („Ahoj!“); }
Pri potvrdení na GitHub som tiež pridal počítadlo, aby sa prehliadaču ukázalo, že každá požiadavka je jedinečná.
Krok 7: Záver
Toto je koniec tohto pokynu. Teraz máte Arduino / ESP, ktoré obsluhuje malú webovú stránku, ktorá hovorí prehliadaču návštevníka, aby načítal súbor JavaScript z cloudu. Po načítaní JavaScriptu sa vytvorí zvyšok obsahu webovej stránky a poskytne používateľské rozhranie pre komunikáciu s Arduino / ESP.
Teraz je na vašej predstavivosti, aby ste na webovej stránke vytvorili viac prvkov a uložili nastavenia lokálne na nejaký druh pamäte ROM (EEPROM / NVS / atď.).
Ďakujeme, že ste si to prečítali, a neváhajte nám poskytnúť spätnú väzbu!
Odporúča:
Ako získať bezplatnú webovú stránku (TLD, hosting, SSL): 16 krokov
Ako získať bezplatnú webovú stránku (TLD, hosting, SSL): Webové stránky sa stávajú veľkou vecou. Predtým mali svoje webové stránky veľké spoločnosti, ako napríklad Microsoft, Google a podobne. Možno to urobili aj niektorí blogeri a menšie spoločnosti. Ale teraz, obzvlášť počas tejto pandémie COVID-19 (áno, píšem to v roku 2020),
Ako vytvoriť jednoduchú webovú stránku pomocou zátvoriek pre začiatočníkov: 14 krokov
Ako vytvoriť jednoduchú webovú stránku pomocou zátvoriek pre začiatočníkov: Úvod Nasledujúce pokyny poskytujú podrobné pokyny na vytvorenie webovej stránky pomocou zátvoriek. Bracket je editor zdrojového kódu, ktorý sa primárne zameriava na vývoj webových aplikácií. Vytvorený spoločnosťou Adobe Systems, je bezplatný a licencovaný softvér s otvoreným zdrojovým kódom
Ako nainštalovať certifikát SSL na webovú stránku WordPress: 5 krokov
Ako nainštalovať certifikát SSL na webovú stránku WordPress: Budeme zdieľať sprievodcu inštaláciou certifikátu SSL na webovú stránku WordPress. Pred inštaláciou certifikátu však musíte nájsť lacného poskytovateľa certifikátu SSL, ako je certifikát SSL Comodo
Maják/eddystone a Adafruit NRF52, propagujte jednoducho svoju webovú stránku/produkt: 4 kroky
Beacon/eddystone and Adafruit NRF52, Inzerujte svoj web/produkt ľahko: Ahoj všetci, dnes sa s vami chcem podeliť o projekt, ktorý som nedávno urobil. Hľadal som zariadenie, ktoré by ho prepojilo vnútorné/vonkajšie a umožnilo ľuďom pripojiť sa k nemu pomocou svojho smartfónu a umožnite im navštíviť konkrétny web alebo inzerovať
Zlúčte svoju webovú stránku (Google Page Creator) s albumom Picasa on Line: 5 krokov
Zlúčte svoju webovú stránku (Google Page Creator) s albumom programu Picasa on -line: Dobrý deň, tu je môj prvý pokyn, užite si ho! pokračovanie týmto návodom na nastavenie webovej stránky pomocou programu Google Page Creator