wpa_supplicant finaliza el proceso si se detecta una contraseña incorrecta

wpa_supplicant finaliza el proceso si se detecta una contraseña incorrecta

Normalmente, cuando ejecuto wpa_supplicantobtengo un resultado como este:

Successfully initialized wpa_supplicant
ioctl[SIOCSIWAP]: Operation not permitted
ioctl[SIOCSIWENCODEEXT]: Invalid argument
ioctl[SIOCSIWENCODEEXT]: Invalid argument
wlan3: Trying to associate with 9c:3d:cf:fb:95:96 (SSID='Bell420' freq=2462 MHz)
wlan3: Association request to the driver failed
wlan3: Associated with 9c:3d:cf:fb:95:96
wlan3: Authentication with 9c:3d:cf:fb:95:96 timed out.
ioctl[SIOCSIWAP]: Operation not permitted
wlan3: CTRL-EVENT-DISCONNECTED bssid=9c:3d:cf:fb:95:96 reason=3 locally_generated=1
wlan3: WPA: 4-Way Handshake failed - pre-shared key may be incorrect

El problema es que lo sigue intentando una y otra vez.

¿Hay alguna manera de saber wpa_supplicantque debo salir tan pronto como aparezca un error obvio como una clave incorrecta?

Estoy en un dispositivo integrado más antiguo con wpa_supplicant v2.1.


Escribí una solución alternativa para monitorear wpa_supplicantclaves incorrectas. Usando grepen wpa_supplicant(con stdbufbasado enEl comentario de Stéphane Chazelas aquí):

  # Create conf file with ssid and password
  wpa_passphrase "$ssid" "$password" > /etc/wpa_supplicant/wpa_supplicant.conf

  # If wifi key is wrong kill subshell
  subshell=$BASHPID
  (sudo stdbuf -o0 wpa_supplicant -Dwext -iwlan1 -c/etc/wpa_supplicant/wpa_supplicant.conf 2>&1 \
    | grep -m 1 "pre-shared key may be incorrect" \
    && kill -s PIPE "$subshell") &

Nota: el bloque anterior está dentro de una subcapa en un script.

Al principio pareció funcionar, pero con el tiempo descubrí que a veces provocaba que todo el script fallara cuando la contraseña estaba bien. Otras veces funcionaría como se esperaba.

Debe haber una mejor manera de hacer esto.


Editar: ¿Quizás debería usar wpa_cliaquí?

Respuesta1

#!/bin/bash

# SSID and password
ssid="YourSSID"
password="YourPassword"

# Create wpa_supplicant.conf
wpa_passphrase "$ssid" "$password" > /etc/wpa_supplicant/wpa_supplicant.conf

# Run wpa_supplicant in the background
wpa_supplicant -Dwext -iwlan1 -c/etc/wpa_supplicant/wpa_supplicant.conf > /tmp/wpa_supplicant.log 2>&1 &

# Monitor log file for error messages
tail -f /tmp/wpa_supplicant.log | while read -r line; do
    if [[ $line == *"pre-shared key may be incorrect"* ]]; then
        echo "Incorrect key detected. Exiting..."
        kill $!
    fi
done

wpa_supplicantse ejecuta en segundo plano y su salida se redirige a un archivo de registro. El tailcomando lee continuamente el archivo de registro y busca el mensaje de error especificado. Si se encuentra el mensaje de error, imprime un mensaje y finaliza el script matando el wpa_supplicantproceso.

información relacionada