ESP8266 – Relaissteuerung über das Web
Dieses Tutorial zeigt Ihnen, wie Sie ein Relais über eine Weboberfläche mithilfe eines Browsers auf einem PC oder Smartphone steuern, wobei der ESP8266 verwendet wird. Im Detail wird der ESP8266 so programmiert, dass er als Webserver arbeitet. Angenommen, die IP-Adresse des ESP8266 lautet 192.168.0.3. Hier sind die Details, wie es funktioniert:
- Wenn Sie 192.168.0.3 in den Webbrowser eingeben, sendet der Webbrowser eine Anfrage an den ESP8266, und der ESP8266 antwortet mit einer Webseite, die den Ein/Aus-Schalter zur Steuerung des Relais enthält.
- In ähnlicher Weise, wenn Sie auf der Webseite die Schaltfläche „Einschalten“ klicken oder 192.168.0.3/relay1/on in den Webbrowser eingeben, schaltet der ESP8266 das Relais ein und antwortet mit der Steuerungs-Webseite.
- Ebenso, wenn Sie auf der Webseite die Schaltfläche „Ausschalten“ klicken oder 192.168.0.3/relay1/off in den Webbrowser eingeben, schaltet der ESP8266 das Relais aus und antwortet mit der Steuerungs-Webseite.

Wir lernen anhand von zwei Beispielcodes:
- HTML-Inhalt ist in den ESP8266-Code eingebettet.
- HTML-Inhalt ist vom ESP8266-Code getrennt und in eine .h-Datei eingefügt.
Das Tutorial bietet die Grundlagen, die Sie problemlos und innovativ anpassen können, um Folgendes zu erreichen:
- Mehrere Relais über das Web steuern
- Neugestaltung der Web-Benutzeroberfläche (UI)
Erforderliche Hardware
Oder Sie können die folgenden Kits kaufen:
1 | × | DIYables Sensor-Kit (30 Sensoren/Displays) | |
1 | × | DIYables Sensor-Kit (18 Sensoren/Displays) |
Über Relais und ESP8266
Wenn du nichts über Relais und den ESP8266 weißt (Pinbelegung, wie es funktioniert, wie man programmiert ...), informiere dich in den folgenden Tutorials darüber:
Verdrahtungsdiagramm

Dieses Bild wurde mit Fritzing erstellt. Klicken Sie, um das Bild zu vergrößern.
Weitere Informationen finden Sie unter ESP8266-Pinbelegung und wie man ESP8266 und andere Komponenten mit Strom versorgt.
ESP8266-Code - HTML-Inhalt ist in den ESP8266-Code eingebettet
Schnelle Schritte
Um mit dem ESP8266 in der Arduino-IDE zu beginnen, folgen Sie diesen Schritten:
- Schauen Sie sich das Tutorial wie man die Umgebung für ESP8266 in der Arduino IDE einrichtet an, falls dies Ihre erste Verwendung von ESP8266 ist.
- Verdrahten Sie die Bauteile wie im Diagramm gezeigt.
- Schließen Sie das ESP8266-Board mit einem USB-Kabel an Ihren Computer an.
- Öffnen Sie die Arduino-IDE auf Ihrem Computer.
- Wählen Sie das richtige ESP8266-Board aus, z. B. (NodeMCU 1.0 (ESP-12E Module)), und verwenden Sie den entsprechenden COM-Port.
- Kopieren Sie den obigen Code und öffnen Sie ihn in der Arduino-IDE.
- Passen Sie im Code die WLAN-Informationen (SSID und Passwort) an Ihre eigenen an.
- Klicken Sie in der Arduino-IDE auf die Schaltfläche Upload, um den Code auf den ESP8266 hochzuladen.
- Öffnen Sie den seriellen Monitor.
- Überprüfen Sie das Ergebnis im seriellen Monitor.
- Sie sehen eine IP-Adresse, zum Beispiel: 192.168.0.3. Dies ist die IP-Adresse des ESP8266-Webservers
- Öffnen Sie einen Webbrowser und geben Sie eines der drei untenstehenden Formate in die Adressleiste ein:
- Bitte beachten Sie, dass die IP-Adresse variieren kann. Überprüfen Sie bitte den aktuellen Wert im seriellen Monitor.
- Sie werden außerdem die folgende Ausgabe im seriellen Monitor sehen.
- Überprüfen Sie den Relaiszustand
- Sie sehen die Webseite des ESP8266-Boards im Webbrowser wie unten dargestellt

- Sie können das Relais nun über die Weboberfläche ein- und ausschalten.
ESP8266-Code - HTML-Inhalt ist vom ESP8266-Code getrennt
Da eine grafische Webseite eine große Menge HTML-Inhalte enthält, wird das Einbetten in den ESP8266-Code wie bisher unpraktisch. Um dieses Problem anzugehen, müssen der ESP8266-Code und der HTML-Code in verschiedene Dateien aufgeteilt werden:
- Der ESP8266-Code wird in einer .ino-Datei abgelegt.
- Der HTML-Code (einschließlich HTML, CSS und JavaScript) wird in einer .h-Datei abgelegt.
Schnelle Schritte
- Öffnen Sie die Arduino-IDE und erstellen Sie einen neuen Sketch. Geben Sie ihm einen Namen, zum Beispiel, newbiely.com.ino
- Kopieren Sie den untenstehenden Code und öffnen Sie ihn mit der Arduino-IDE
- Passe die WiFi-Informationen (SSID und Passwort) im Code an deine eigenen an
- Erstelle die Datei index.h im Arduino IDE, indem du:
- Entweder klickst du auf die Schaltfläche direkt unter dem Symbol des seriellen Monitors und wählst Neuer Tab, oder verwendest du die Tastenkombination Ctrl+Shift+N
- Geben Sie den Dateinamen index.h ein und klicken Sie auf die OK-Schaltfläche
- Kopieren Sie den folgenden Code und fügen Sie ihn in die index.h ein.
- Jetzt haben Sie den Code in zwei Dateien: newbiely.com.ino und index.h
- Klicken Sie in der Arduino IDE auf die Hochladen-Schaltfläche, um den Code auf den ESP8266 hochzuladen.
- Greifen Sie wie zuvor über einen Webbrowser auf die Webseite des ESP8266-Boards zu. Sie wird ähnlich wie der vorherige Code unten angezeigt:
- Wenn Sie den HTML-Inhalt in der index.h ändern und nichts in der newbiely.com.ino-Datei berühren, wird beim Kompilieren und Hochladen des Codes auf den ESP8266 die HTML-Inhalte nicht aktualisiert.
- Um die Arduino IDE in diesem Fall dazu zu bringen, den HTML-Inhalt zu aktualisieren, nehmen Sie eine Änderung in der newbiely.com.ino-Datei vor (z. B. eine leere Zeile hinzufügen, einen Kommentar hinzufügen ...).
- Steuerung mehrerer Relais über das Web
- Neugestaltung der Web-Benutzeroberfläche (UI)



※ Notiz:
Sie können den oben gezeigten Code mühelos und innovativ anpassen, um Folgendes zu erreichen: