ESP32 - WebSocket
En este tutorial, aprenderemos qué es WebSocket, por qué necesitamos usarlo para controlar el ESP32 de forma suave y cómo usar WebSocket con ESP32. En un ejemplo práctico, aprenderemos cómo crear una aplicación de chat entre el navegador web y el ESP32, lo que te permitirá:
- Escribe un mensaje en la ventana de chat del navegador web y envíalo al ESP32. Puedes adaptar esto para controlar el ESP32.
- Recibe mensajes en tiempo real desde el ESP32. Puedes adaptar esto para monitorear el ESP32 en tiempo real.

Hardware Requerido
Or you can buy the following kits:
| 1 | × | DIYables ESP32 Starter Kit (ESP32 included) | |
| 1 | × | DIYables Sensor Kit (30 sensors/displays) | |
| 1 | × | DIYables Sensor Kit (18 sensors/displays) |
¿Qué es ESP32 Websocket?
Ahora, podrías estar preguntándote: '¿Qué es WebSocket?' Es bastante simple: WebSocket es una tecnología que permite que un navegador web hable directamente con un servidor web en tiempo real.
- Sin WebSocket, tienes que actualizar la página web para obtener actualizaciones. Eso no es muy conveniente.
- Con WebSocket, la página web y el servidor permanecen conectados todo el tiempo. Esto significa que pueden compartir información instantáneamente sin necesidad de recargar la página.
Probablemente te encuentres con WebSocket en aplicaciones web de uso diario, como juegos en línea, mensajería instantánea y actualizaciones del mercado de valores.
¿Por qué necesitamos WebSocket para controlar el ESP32 de forma fluida?
Imagina que quieres controlar tu coche teledirigido usando una interfaz web en tu teléfono o computadora. Sin WebSocket, cada vez que quieras cambiar la dirección o la velocidad del coche, tendrías que actualizar la página web. Es como tener que pulsar un botón de recarga cada vez que quieras que tu comando llegue al coche.
Ahora, con WebSocket, es como tener una conexión continua y directa entre tu teléfono o computadora y el coche. Ya no necesitas actualizar la página cada vez que quieras dirigir el coche o ajustar su velocidad. Es como si el coche estuviera siempre atento a tus comandos en tiempo real, sin retrasos causados por la recarga constante de la página.
En general, WebSocket te permite:
- Enviar datos desde el navegador web al ESP32 sin recargar la página web.
- Enviar datos desde el ESP32 al navegador web sin recargar la página web.
Esto facilita la comunicación bidireccional en tiempo real.
Beneficios de WebSocket con ESP32:
- Control en tiempo real: WebSocket permite una comunicación instantánea con el ESP32, asegurando respuestas rápidas a los comandos para una experiencia de usuario fluida.
- Conexión persistente: Mantener un enlace continuo sin actualizar la página de control, creando una línea de comunicación siempre lista para instrucciones inmediatas.
- Eficiencia: Experimenta respuestas rápidas sin necesidad de recargar la página de forma constante, mejorando la satisfacción general del usuario y la eficiencia.
Chat web con ESP32 a través de WebSocket
El contenido de la página web (HTML, CSS, JavaScript) se almacena por separado en un archivo index.h. Por lo tanto, tendremos dos archivos de código en el IDE de Arduino:
- Un archivo .ino con código para ESP32, que crea un servidor web y un servidor WebSocket
- Un archivo .h, que contiene el contenido de la página web
Pasos R\u00e1pidos
- Si es la primera vez que usas ESP32, consulta cómo configurar el entorno para ESP32 en Arduino IDE.
- Conecta la placa ESP32 a tu PC mediante un cable micro USB.
- Abre el IDE de Arduino en tu PC.
- Selecciona la placa ESP32 correcta (p. ej. ESP32 Dev Module) y el puerto COM.
- Abre el Gestor de Bibliotecas haciendo clic en el icono Gestor de Bibliotecas en la barra de navegación izquierda del IDE de Arduino.
- Busca “DIYables ESP32 WebServer”, luego encuentra la biblioteca Web Server creada por DIYables.
- Haz clic en el botón Instalar para instalar la biblioteca Web Server.

- En el IDE de Arduino, crea un nuevo sketch, dale un nombre, por ejemplo, newbiely.com.ino
- Copia el código de abajo y ábrelo con el IDE de Arduino
- Modifica la información de WiFi (SSID y contraseña) en el código para que coincida con tus credenciales de red.
- Crea el archivo index.h en el IDE de Arduino haciendo:
- Haz clic en el botón justo debajo del icono del monitor serie y elige Nueva pestaña, o usa las teclas Ctrl+Shift+N.
- Escribe el nombre del archivo index.h y haz clic en el OK botón
- Copia el código de abajo y pégalo en index.h.
- Ahora tienes el código en dos archivos: newbiely.com.ino y index.h
- Haz clic en el botón Subir en el IDE de Arduino para subir el código al ESP32.
- Abre el Monitor Serial
- Consulta el resultado en el Monitor Serial.
- Tome nota de la dirección IP que se muestra y escriba esta dirección en la barra de direcciones de un navegador web en su teléfono inteligente o PC.
- Verá la página web tal como se muestra a continuación:
- Haz clic en el botón CONECTAR para conectar la página web al ESP32 mediante WebSocket.
- Escribe algunas palabras y envíalas al ESP32.
- Verás la respuesta del ESP32.
- Si modificas el contenido HTML en el index.h y no tocas nada en el archivo newbiely.com.ino, cuando compiles y cargues el código al ESP32, el IDE de Arduino no actualizará el contenido HTML.
- Para que el IDE de Arduino actualice el contenido HTML en este caso, realiza un cambio en el archivo newbiely.com.ino (p. ej., agregar una línea en blanco, añadir un comentario...).




※ Nota:
Explicación del código línea por línea
El código ESP32 anterior contiene una explicación línea por línea. Por favor, lea los comentarios en el código.
Cómo funciona el sistema
El código para ESP32 funciona creando tanto un servidor web como un servidor WebSocket. El proceso se desarrolla de la siguiente manera:
- Cuando introduces la dirección IP del ESP32 en un navegador web, se realiza una solicitud de la página web (Interfaz de usuario) desde el ESP32.
- El servidor web del ESP32 responde transmitiendo el contenido de la página web (HTML, CSS, JavaScript).
- Posteriormente, tu navegador web muestra la página.
- Cuando haces clic en el botón CONECTAR, el código JavaScript incrustado en la página web establece una conexión WebSocket con el servidor WebSocket en el ESP32.
- Con la conexión WebSocket establecida, cuando escribes algo y haces clic en el botón ENVIAR, el código JavaScript envía ese texto al ESP32 a través de la conexión WebSocket en segundo plano.
- Al recibir el valor del ángulo, el servidor WebSocket envía de vuelta una respuesta a la página web.
Puedes aprender otros ejemplos de WebSocket para ESP32 a continuación: