現在、WiFiネットワークから切断し、次に基づいて再接続する次のスクリプトがありますwpa_supplicant.conf
。
#!/bin/bash
if iwgetid; then
sudo wpa_cli terminate
sudo ip addr flush wlan0
sudo ip link set dev wlan0 down
sudo rm -r /var/run/wpa_supplicant > /dev/null
fi
sudo wpa_supplicant -B -i wlan0 -c /etc/wpa_supplicant/wpa_supplicant.conf > /dev/null 2>&1
sudo service ntp restart
sudo ip link set dev wlan0 down
sudo ip link set dev wlan0 up
sudo dhclient wlan0
問題は、資格情報がwpa_supplicant
正しくない場合(私のアプリケーションのユーザー入力に基づいているため、そうである可能性が非常に高い)、dhclient
DHCPサーバーに接続してIPアドレスを割り当てようとすると、かなり長い間停止し、最終的に失敗することです。 。
電話する前に資格情報が正しいことをテストする方法はありますかdhclient
?
ベストアンサー1
以下は、Theとtheを設定するコマンドを./script
含む例です。wpa_passphrase
SSID
password
#!/bin/bash
if iwgetid; then
wpa_cli terminate
ip addr flush wlan0
ip link set dev wlan0 down
rm -r /var/run/wpa_supplicant > /dev/null
ip link set dev wlan0 up
fi
wpa_supplicant -B -i wlan0 -c<(wpa_passphrase "$1" "$2") > /dev/null 2>&1
dhclient wlan0
service ntp restart
exit
使用法:
sudo ./script "My SSID" "My-Password"
修正する
wpa_supplicant
指定された認証で認証が成功すると、ログファイルが受信されますssid
。pass
WPA: Key negotiation completed
-f
wpa_supplicant
ファイルのオプションを指定するには、コマンドに追加しますlog
。
grep
コマンドを実行する前に終了ステータスを確認できますdhclient
。
#!/bin/bash
if iwgetid; then
wpa_cli terminate
ip addr flush wlan0
ip link set dev wlan0 down
rm -r /var/run/wpa_supplicant > /dev/null
ip link set dev wlan0 up
fi
# A minimal wpa_supplicant.conf configuration file.
echo -e "\nctrl_interface=/run/wpa_supplicant \nupdate_config=1\n" > /etc/wpa_supplicant/wpa_supplicant.conf
# A prompt for SSID and WPA passphrase. The -f option to get a log file.
# sleep command will be useful because the authentication will take a few
# second before executing grep.
echo "" > logfile
wpa_supplicant -B -i wlan0 -c<(wpa_passphrase "$1" "$2") -f logfile
sleep 10
grep -c "WPA: Key negotiation completed" logfile
if [ $? -eq 0 ]
then
echo "Key negotiation completed successfully"
timeout 15 dhclient wlan0
exit 0
else
echo "Authentication failed"
fi
exit 1
使用法:
sudo ./script "My SSID" "My-Password"