Estándares · QR de credenciales Wi-Fi

¿Es seguro escanear este código QR de Wi-Fi?

Un QR de Wi-Fi une tu teléfono a la red cuyo nombre está dentro del código, sin más. El peligro no es el formato QR (está estandarizado y es inofensivo por sí solo), sino el SSID. Un QR con un nombre como «Starbucks-WiFi-Free» podría llevarte a un punto de acceso falso en el aparcamiento. La defensa es leer el nombre de la red ANTES de pulsar Conectar.

Inspeccionar un QR de Wi-Fi → Todos los estándares →

¿Cuál es el formato?

El estándar es el esquema URI WIFI:, introducido originalmente por el proyecto ZXing y adoptado por la Wi-Fi Alliance. Un payload completo tiene este aspecto:

WIFI:T:WPA2;S:CafeWiFi;P:hunter2;H:false;;

Los campos son pares clave-valor separados por punto y coma. Todas las aplicaciones de cámara de teléfonos modernos reconocen este formato y ofrecen unirse a la red.

Para WPA2-Enterprise (Wi-Fi corporativo o de campus), el formato se amplía con tres campos más: método EAP (PEAP / TLS / TTLS), identidad (tu nombre de usuario), identidad anónima (la identidad EAP exterior) y método de autenticación de fase 2.

Campo por campo

T, Tipo de seguridad

WPA, WPA2, WPA3, WEP o nopass (abierta). WEP está comprometido; los teléfonos modernos pueden negarse a conectarse. nopass significa que la red es abierta sin cifrado en la capa de enlace.

S, SSID (nombre de red)

El nombre de red que tu teléfono muestra después de conectarse. El campo más importante que debes verificar. Compáralo con lo que el local anuncia en material impreso o en señales.

P, Contraseña

La clave precompartida para redes de clase WPA. Ausente para nopass.

H, Red oculta

true si la red no difunde su SSID. Las redes ocultas requieren búsqueda activa; no son inherentemente más seguras, a menudo menos.

E, Método EAP (Enterprise)

Para redes WPA2/3-Enterprise: PEAP, TLS, TTLS, PWD. Determina cómo tu teléfono se autentifica ante el servidor de autenticación de la red.

I, Identidad (Enterprise)

Tu nombre de usuario en la red Enterprise. Algunos locales codifican una identidad de invitado aquí; las redes corporativas esperan tu nombre de usuario real.

A, Identidad anónima (Enterprise)

La identidad exterior visible durante el handshake EAP. Se usa para privacidad; la identidad real está cifrada dentro del túnel.

PH2, Método de fase 2 (Enterprise)

Para TTLS / PEAP: el método de autenticación del túnel interior, generalmente MSCHAPV2.

El ataque del gemelo malicioso

La receta:

  1. El atacante instala un router Wi-Fi (o un teléfono en modo punto de acceso) cerca de un local objetivo: una cafetería, una puerta de aeropuerto, el vestíbulo de un hotel, un centro de conferencias.
  2. Configura el SSID para que coincida con o imite la red del local: Starbucks_WiFi_2, FREE_AIRPORT_WIFI, HotelGuests_5G.
  3. Imprime un QR para esa red falsa y lo pega en algún lugar plausible: bajo el borde de una mesa, junto a un enchufe, en una ventana.
  4. Escaneas, tu teléfono se une a su punto de acceso. El atacante proxifica tu tráfico hacia internet real para que nada parezca roto, pero ve cada nombre de host SNI del handshake HTTPS (qué sitios visitas), cada consulta DNS y cualquier tráfico no cifrado.

Las aplicaciones modernas usan HTTPS, por lo que las credenciales y el contenido están cifrados. Pero:

Nuestro escáner marca los SSIDs que parecen objetivos de alta suplantación, nombres de marcas conocidas con confusables decodificados, como sospechosos para que compruebes el nombre de la red antes de unirte.

Qué muestra nuestro escáner

Arrastra un QR de Wi-Fi (imagen, pegar o cámara) a nuestro escáner. El veredicto muestra:

El escáner se ejecuta en tu navegador; solo el texto decodificado llega a nuestro servidor para la verificación de seguridad, no la imagen.

Antes de pulsar Conectar

Relacionado

Inspeccionar un QR de Wi-Fi

Arrastra la imagen del QR, pega la cadena WIFI: o usa la cámara. El veredicto muestra el nombre de la red, el tipo de seguridad, la contraseña enmascarada y marca similares frente a SSIDs de marcas de alta suplantación.

Abrir escáner →