Table des matières:
- Conditions préalables
- Étape 1: Commencer avec un simple croquis de serveur Web
- Étape 2: Création du JavaScript distant
- Étape 3: Chargement du fichier JavaScript distant dans le navigateur des visiteurs
- Étape 4: Ajout de nouveaux éléments à la page
- Étape 5: Éléments interactifs
- Étape 6: Répondre à l'élément interactif
- Étape 7: Conclusion
2025 Auteur: John Day | [email protected]. Dernière modifié: 2025-01-23 14:46
Lors de la création d'un projet Arduino / ESP (ESP8266/ESP32), vous pouvez simplement tout coder en dur. Mais le plus souvent, quelque chose se produit et vous finirez par rattacher à nouveau votre appareil IoT à votre IDE. Ou vous avez simplement plus de personnes accédant à la configuration et vous souhaitez fournir une interface utilisateur au lieu de vous attendre à ce qu'elles comprennent le fonctionnement interne.
Cette instructable vous dira comment mettre la plupart de l'interface utilisateur dans le cloud au lieu de sur l'Arduino / ESP. En procédant de cette manière, vous économiserez de l'espace et de la mémoire. Un service fournissant des pages Web statiques gratuites est particulièrement adapté en tant que "cloud", comme les pages GitHub, mais d'autres options fonctionneront probablement également.
Pour créer la page Web de cette manière, le navigateur de l'utilisateur doit suivre 4 étapes:
- Demander l'url racine de l'Arduino / ESP
- Recevez une page Web très simple, indiquant à:
- Demander un fichier JavaScript depuis le cloud
- Recevez le code qui construit la page réelle
Ce Instructable expliquera également comment interagir avec l'Arduino/ESP une fois que la page est prête selon les étapes ci-dessus.
Le code créé sur cette instructable se trouve également sur GitHub.
Conditions préalables
Cette instructable suppose que vous avez accès à certains matériaux et à certaines connaissances préalables:
- Un Arduino (avec accès réseau) / ESP
- Un ordinateur auquel connecter ce qui précède
- Accès WiFi connecté à internet
- L'IDE Arduino installé (également pour l'ESP32)
- Vous savez comment télécharger un croquis sur votre appareil IoT
- Vous savez utiliser Git & GitHub
Étape 1: Commencer avec un simple croquis de serveur Web
Nous allons commencer aussi simplement que possible, et le laisser grandir à partir de maintenant.
#comprendre
const char* ssid = "yourssid"; const char* mot de passe = "votrepasswd"; Serveur WiFiServer (80); void setup() { //Initialize serial et attendez que le port s'ouvre: Serial.begin(115200); while(!Série) {; // attend que le port série se connecte. Nécessaire pour le port USB natif uniquement } WiFi.begin(ssid, mot de passe); while(WiFi.status() != WL_CONNECTED) { delay(500); Serial.print("."); } Serial.println("WiFi connecté."); Serial.println("Adresse IP: "); Serial.println(WiFi.localIP()); serveur.begin(); } void loop() { // écouter les clients entrants WiFiClient client = server.available(); // écoute les clients entrants bool sendResponse = false; // défini sur true si nous voulons envoyer une réponse String urlLine = ""; // crée une chaîne pour contenir l'URL demandée if(client) // si vous obtenez un client, { Serial.println("Nouveau client."); // affiche un message sur le port série String currentLine = ""; // crée une chaîne pour contenir les données entrantes du client while(client.connected()) // boucle pendant que le client est connecté { if(client.available()) // s'il y a des octets à lire depuis le client, { char c = client.lire(); // lit un octet, puis if(c == '\n') // si l'octet est un caractère de nouvelle ligne { // si la ligne actuelle est vide, vous avez deux caractères de nouvelle ligne d'affilée. // c'est la fin de la requête HTTP du client, alors envoyez une réponse: if(currentLine.length() == 0) { sendResponse = true; // tout va bien! Pause; // sortir de la boucle while } else // si vous avez une nouvelle ligne, alors effacez currentLine: { if(currentLine.indexOf("GET /") >= 0) // cela devrait être la ligne URL { urlLine = currentLine; // enregistrez-le pour une utilisation ultérieure } currentLine = ""; // réinitialise la chaîne currentLine } } else if(c != '\r') // si vous avez autre chose qu'un caractère de retour chariot, { currentLine += c; // l'ajoute à la fin de la ligne courante } } } if(sendResponse) { Serial.print("Client demandé "); Serial.println(urlLine); // Les en-têtes HTTP commencent toujours par un code de réponse (par exemple HTTP/1.1 200 OK) // et un type de contenu afin que le client sache ce qui va arriver, puis une ligne vide: client.println("HTTP/1.1 200 OK"); client.println("Content-type:text/html"); client.println(); if(urlLine.indexOf("GET / ") >= 0) // si l'URL n'est qu'un "/" { // le contenu de la réponse HTTP suit l'en-tête: client.println("Hello world!"); } // La réponse HTTP se termine par une autre ligne vide: client.println(); } // ferme la connexion: client.stop(); Serial.println("Client déconnecté."); } }
Copiez le code ci-dessus ou téléchargez-le à partir du commit sur GitHub.
N'oubliez pas de changer le SSID et le mot de passe pour qu'ils correspondent à votre réseau.
Ce croquis utilise le bien connu Arduino
mettre en place()
et
boucle()
les fonctions. Dans le
mettre en place()
fonction, la connexion série à l'IDE est initialisée, de même que le WiFi. Une fois que le WiFi est connecté audit SSID, l'IP est imprimée et le serveur Web est démarré. A chaque itération du
boucle()
fonction, le serveur Web est vérifié pour les clients connectés. Si un client est connecté, la requête est lue et l'URL demandée est enregistrée dans une variable. Si tout semble bien, une réponse du serveur au client est effectuée en fonction de l'URL demandée.
ATTENTION! Ce code utilise la classe Arduino String pour rester simple. Les optimisations de chaîne ne sont pas dans le cadre de cette instructable. En savoir plus à ce sujet sur l'instructable about Arduino String Manipulation Using Minimal Ram.
Étape 2: Création du JavaScript distant
L'Arduino / ESP dira au navigateur du visiteur de charger ce fichier. Tout le reste sera fait par ce code JavaScript.
Dans ce Instructable, nous utiliserons jQuery, ce n'est pas strictement nécessaire, mais facilitera les choses.
Ce fichier doit être accessible depuis le web, un serveur de pages statiques suffit pour que cela fonctionne, par exemple des pages GitHub. Vous voudrez donc probablement créer un nouveau référentiel GitHub et créer un
gh-pages
branche. Mettez le code suivant dans un
.js
dans le référentiel dans la branche appropriée.
Copiez le code ci-dessus ou téléchargez-le à partir du commit sur GitHub.
Vérifiez si votre fichier est accessible. Dans le cas des pages GitHub, accédez à https://username.github.io/repository/your-file.j… (remplacez
Nom d'utilisateur
,
dépôt
et
votre-fichier.js
pour les bons paramètres).
Étape 3: Chargement du fichier JavaScript distant dans le navigateur des visiteurs
Maintenant que tout est configuré, il est temps que la page Web charge le fichier JavaScript distant.
Vous pouvez le faire en changeant la ligne 88 du croquis de
client.println("Bonjour tout le monde!"); t
client.println("");
(changer la
src
attribut pour pointer vers votre propre fichier JavaScript). Il s'agit d'une petite page Web HTML, tout ce qu'elle fait est de charger le fichier JavaScript dans le navigateur des visiteurs.
Le fichier modifié peut également être trouvé dans le commit correspondant sur GitHub.
Téléchargez le croquis ajusté sur votre Arduino / ESP.
Étape 4: Ajout de nouveaux éléments à la page
Une page vide est inutile, il est donc temps d'ajouter un nouvel élément à la page Web. Pour l'instant, ce sera une vidéo YouTube. Dans cet exemple, certains codes jQuery seront utilisés pour accomplir cela.
Ajoutez la ligne de code suivante au
init()
fonction:
$('').prop({ src: 'https://www.youtube.com/embed/k12h_FOInZg?rel=0', frameborder: '0' }).css({ width: '608px', height: '342px' }).appendTo('body');
Cela créera un
iframe
élément, définissez le bon
src
attribut et définissez la taille à l'aide de css et ajoutez l'élément au corps de la page.
jQuery nous aide à sélectionner et à modifier facilement des éléments de la page Web, quelques éléments de base à savoir:
-
$('corps')
- sélectionne tout élément déjà existant, d'autres sélecteurs CSS peuvent également être utilisés
-
$(' ')
crée un nouveau
- élément (mais ne l'ajoute pas au document)
-
.appendTo('.main')
- ajoute l'élément sélectionné/créé à un élément avec la classe css 'main'
-
D'autres fonctions pour ajouter des éléments sont
.ajouter()
,
.prepend()
,
.prependTo()
,
.insérer()
,
.insertAfter()
,
.insertAvant()
,
.après()
,
.avant()
Jetez un œil au commit correspondant sur GitHub si quelque chose n'est pas clair.
Étape 5: Éléments interactifs
Une vidéo est amusante, mais le but de cette instructable est d'interagir avec l'Arduino / ESP. Remplaçons la vidéo par un bouton qui envoie des informations à l'Arduino / ESP et attend également une réponse.
Nous aurons besoin d'un
$('')
à ajouter à la page et y attacher un écouteur d'événement. L'écouteur d'événement appellera la fonction de rappel lorsque l'événement spécifié se produira:
$('').text('un bouton').on('click', function()
{ // le code ici sera exécuté lorsque le bouton sera cliqué }).appendTo('body');
Et ajoutez une requête AJAX à la fonction de rappel:
$.get('/ajax', fonction(données)
{ // le code ici sera exécuté lorsque la requête AJAX sera terminée });
Une fois la demande terminée, les données renvoyées seront ajoutées à la page:
$('
').text(data).appendTo('body');
En résumé, le code ci-dessus crée un bouton, l'ajoute à la page Web, lorsque le bouton est cliqué, une demande sera envoyée et la réponse sera également ajoutée à la page Web.
Si c'est la première fois que vous utilisez des rappels, vous voudrez peut-être vérifier le commit sur GitHub pour voir comment tout est imbriqué.
Étape 6: Répondre à l'élément interactif
Bien entendu, la requête AJAX nécessite une réponse.
Pour créer la réponse correcte pour le
/ajax
URL, nous devrons ajouter un
sinon si ()
juste après le crochet fermant de l'instruction if qui vérifie le
/
URL.
else if(urlLine.indexOf("GET /ajax") >= 0)
{ client.print("Bonjour!"); }
Dans le commit sur GitHub, j'ai également ajouté un compteur pour montrer au navigateur que chaque requête est unique.
Étape 7: Conclusion
C'est la fin de cette instructable. Vous disposez maintenant d'un Arduino/ESP desservant une petite page Web qui indique au navigateur du visiteur de charger un fichier JavaScript depuis le cloud. Une fois que JavaScript est chargé, il crée le reste du contenu de la page Web en fournissant une interface utilisateur permettant à l'utilisateur de communiquer avec l'Arduino / ESP.
Maintenant, c'est à votre imagination de créer plus d'éléments sur la page Web et d'enregistrer les paramètres localement sur une sorte de ROM (EEPROM / NVS / etc.).
Merci d'avoir lu et n'hésitez pas à donner votre avis !
Conseillé:
Chargez votre téléphone avec une batterie de voiture (6V-24V): 6 étapes
Chargez votre téléphone avec une batterie de voiture (6V-24V): Charger votre smartphone en camping à l'extérieur n'est pas toujours facile. Je vous montre comment recharger votre téléphone en utilisant une batterie de voiture et une batterie de cyclomoteur. Vous pouvez également utiliser le gadget avec n'importe quel type de source d'alimentation 6V-24V
Chargez votre téléphone avec des piles AA ! ? : 3 étapes
Chargez votre téléphone avec des piles AA !? : Voici un petit tutoriel utile sur la façon d'utiliser des piles pour charger votre téléphone. Dans mon cas, j'ai utilisé 3 piles AA mais cela fonctionne également avec seulement deux en série. Il s'agit d'une extension d'un projet précédent. Assurez-vous de regarder celui-ci en premier : https://www.instr
Android Home (contrôlez votre maison depuis votre téléphone) : 4 étapes
Android Home (contrôlez votre maison depuis votre téléphone) : mon plan final est d'avoir ma maison sur ma poche, ses commutateurs, ses capteurs et sa sécurité. puis auto mate itIntroduction : Salut, Ich bin zakriya et cette "Maison Android" est mon projet, ce projet est d'abord de quatre instructables à venir, dans
Fusionner votre page Web (Google Page Creator) avec Picasa on Line Album : 5 étapes
Fusionnez votre page Web (créateur de page Google) avec Picasa sur l'album en ligne : Bonjour, voici mon premier Instructable, profitez-en ! continuer avec cette instructable Configuration d'un site Web avec le créateur de page de Google
Comment rediffuser le WIFI en tant que votre propre réseau, DEPUIS VOTRE ORDINATEUR PORTABLE ! : 4 étapes
Comment rediffuser le WIFI en tant que votre propre réseau, DE VOTRE ORDINATEUR PORTABLE ! : Dans ce instructable, je vais vous montrer comment rediffuser le WIFI depuis votre ordinateur portable en tant que votre propre réseau protégé par mot de passe. Vous aurez besoin d'un ordinateur portable exécutant Windows 7, car le logiciel nécessite certaines des avancées de Windows 7 et utilisez un ordinateur portable plus récent b