Skip to content

Latest commit

 

History

History
131 lines (82 loc) · 8.13 KB

README.md

File metadata and controls

131 lines (82 loc) · 8.13 KB

Simple Portal Web para ESP8266/ESP32

Simple portal web para configurar las credenciales de una red WiFi en un dispositivo construido alrededor de un ESP8266 o de un ESP32.

Se trata de un pequeño Captive Portal que permite configurar las credenciales WiFi, tanto el SSID (Service Set IDentifier) como la Password a un usuario final que tenga algún dispositivo IoT basado en el SoC ESP8266 o ESP32.

Para acceder al portal hay que conectarse a la red WiFi que genera el ESP, por defecto el nombre de la red es ESP WebServer, y desde el navegador dirigirse a la IP 192.168.4.1.

Captive Portal

El funcionamiento del sistema es muy simple:

  1. Inicia el sistema con el encendido de la placa.
  2. wifiConnect() intenta conectar durante 5 segundos utilizando las credenciales almacenadas en la memoria EEPROM interna, para luego ejecutar funciones auxiliares (como manejar un LED Status). En caso contrario, es decir si falla la conexión, invoca a wifiAP().
  3. wifiAP() genera una red WiFi para que el cliente se pueda conectar. Acto seguido deberá ingresar mediante el navegador a la dirección IP del Captive Portal, completar el formulario con los datos de la red a la que desea conectar el dispositivo y presionar el botón Guardar. El sistema se reiniciará y volverá a ejecutar el paso (1).
  4. Es posible forzar el Captive Portal en caso de querer cambiar las credenciales almacenadas, para esto simplemente se pulsa el botón RESET.

Descripción del código

Para compilar el proyecto son necesarias las siguientes dependencias, incluidas en el ESP8266 Arduino Core:

Para el ESP32, incluidas en el ESP32 Arduino Core:

Todo el código esta contenido en varios archivos para facilitar el mantenimiento:

espWebCfg.h contiene los prototipos de funciones, declaraciones de variables y constantes. Es la inclusión que se debe hacer en el archivo principal, por ejemplo myFirmware.ino.

Incorpora la línea #define ENABLE_DEBUG 1 que permite activar (o no) el modo de depuración vía el monitor Serial. Por defecto esta activado, con 0 se desactiva.

Además hay definidas algunas constantes útiles:

  • MAX_ATTEMPTS es un multiplicador de tiempo para dar por finalizado los intentos fallidos de conexión y lanzar el Captive Portal.
  • RESET se refiere al pin GPIO donde se encuentra conectado un pulsador pull-down para forzar el Captive Portal, por defecto es GPIO04 / G4 / D2 (consulte el pinout de su placa).
  • BLINK_TIME es el tiempo entre destellos del Status LED.
  • FLASH_LED es el tiempo de encendido del Status LED.

espSetupFunction.cpp gestiona distintas configuraciones mediante la función espSetup(). La misma se debe incluir dentro de setup() en el archivo pricipal, por ejemplo myFirmware.ino.

espLoopFunction.cpp contiene la función espLoop() que ejecuta funciones auxiliares. La misma se debe incluir dentro de loop() en el archivo pricipal, por ejemplo myFirmware.ino. Ademas incorpora la función blinkLed() que se encarga de manejar el destello del Status LED, por defecto 100 ms cada 3 segundos.

espWiFi.cpp contiene prácticamente todo el código relacionado a la conectividad WiFi. Se utilizan dos objetos String para almacenar las credenciales WiFi: wifiSsid para el SSID y wifiPassword para la contraseña. La función wifiConnect() es la que maneja la conexión a la red WiFi.

espWebServer.cpp se encarga de generar una red WiFi mediante el modo Soft-AP del ESP, y servir las páginas del Captive Portal. Las funciones incluidas son las siguientes:

  • wifiAP() Maneja el modo Soft-AP
  • handleRootGET() Envía el Captive Portal
  • handleRootPOST() Maneja las peticiones desde el browser

html.cpp contiene el código HTML que se utiliza en el Captive Portal. Actualmente hay dos páginas embebidas:

  • htmlConfig Captive Portal
  • htmlSuccess Mensaje luego de procesar el formulario

espEEPROM.cpp contiene el código relacionado al manejo de la memoria EEPROM interna que se utiliza para almacenar los datos ingresados de manera permanente. Hay disponibles dos constantes que permiten seleccionar las direcciones de la memoria a utilizar: SSID_ADDRESS para el SSID y PASS_ADDRESS para la contraseña.

Las funciones incluidas son las siguientes:

  • readString(int address) Devuelve un String desde la dirección especificada
  • writeString(int address, const String &data) Escribe un String en la dirección especificada
  • saveCredentials(const String &ssid, const String &password) Almacena las credenciales WiFi

Ejemplo de uso

El siguiente código Arduino permite comenzar un proyecto centrándose unicamente en la lógica que deberá llevar adelante el dispositivo, sin preocuparse por la gestión de la conexión.

// File myFirmware.ino

#include "espWebCfg.h"

void setup() {
  espSetup();
}

void loop() {

  espLoop();

  /*
      Acá tu código...
      Considerar no utizar retardos bloqueantes (delay).
  */
}

Hardware

Para las pruebas se utilizó una placa de prototipos NodeMCU genérica, simplemente con un pulsador conectado en el GPIO4, según el siguiente diagrama de conexiones.

Diagrama esquemático

ToDo

  • Agregar soporte para SoC ESP32
  • ¿Agregar soporte para Raspberry Pi Pico W?
  • Validar los datos ingresados mediante los campos del formulario
  • Mejorar el diseño del portal HTML
  • Documentar variantes de hardware
  • Realizar pruebas de funcionamiento

Problemas conocidos

  • No se está escribiendo el SSID en el monitor. espWiFi.cpp, linea 28.

Recursos

Licencia

Este trabajo está protegido por la Licencia MIT. Puedes acceder a la versión original de la licencia (en inglés) a través del archivo LICENSE o en línea en The MIT License (MIT). También proporcionamos una traducción no oficial desde Wikipedia:

Copyright (c) 2024 Lucas Martín Treser

Por la presente se concede permiso, libre de cargos, a cualquier persona que obtenga una copia de este software y de los archivos de documentación asociados (el "Software"), a utilizar el Software sin restricción, incluyendo sin limitación los derechos a usar, copiar, modificar, fusionar, publicar, distribuir, sublicenciar, y/o vender copias del Software, y a permitir a las personas a las que se les proporcione el Software a hacer lo mismo, sujeto a las siguientes condiciones:

El aviso de copyright anterior y este aviso de permiso se incluirán en todas las copias o partes sustanciales del Software.

EL SOFTWARE SE PROPORCIONA "COMO ESTÁ", SIN GARANTÍA DE NINGÚN TIPO, EXPRESA O IMPLÍCITA, INCLUYENDO PERO NO LIMITADO A GARANTÍAS DE COMERCIALIZACIÓN, IDONEIDAD PARA UN PROPÓSITO PARTICULAR E INCUMPLIMIENTO. EN NINGÚN CASO LOS AUTORES O PROPIETARIOS DE LOS DERECHOS DE AUTOR SERÁN RESPONSABLES DE NINGUNA RECLAMACIÓN, DAÑOS U OTRAS RESPONSABILIDADES, YA SEA EN UNA ACCIÓN DE CONTRATO, AGRAVIO O CUALQUIER OTRO MOTIVO, DERIVADAS DE, FUERA DE O EN CONEXIÓN CON EL SOFTWARE O SU USO U OTRO TIPO DE ACCIONES EN EL SOFTWARE.