脚本连接wifi

 

#!/bin/sh
WLAN=${1}
SSID="${2}"
SECURITY=${3}
PASSWORD="${4}"
DRIVER=nl80211

if [ "$#" != "3" -a "$#" != "4" ]; then
	SELF=`basename $0`
	echo "This script support Atheros."
	echo "Usage:"
	echo "    $SELF interface ssid {WEP | WPAPSK | NONE} [password]"
	echo "        interface          - network interface, such as wlan0, ra0"
	echo "        ssid               - SSID string."
	echo "        {WEP|WPAPSK|NONE}  - security mode."
	echo "        password           - password when security mode is WEP"
	echo "                             or WPAPSK."
	echo "example:"
	echo "    $SELF wlan0 dlink WEP 0123456789"
	echo "    $SELF wlan0 dlink WPAPSK password"
	echo "    $SELF wlan0 dlink NONE"
	echo;
	exit 0
fi
################################################################################
NORMAL="\033[00m"
RED="\033[31m"
################################################################################
wpa_supplicant_start ()
{
	echo -e $RED'start wpa_supplicant'$NORMAL
	MSG0=`busybox ps`
	MSG=`echo $MSG0 | grep -r "wpa_supplicant -i$WLAN"`
	if [ ss"$MSG" != ss"" ]; then
		echo "wpa_supplicant is running"
		return 0
	fi

	ifconfig $WLAN down
	test -d /var/run/wpa_supplicant || mkdir /var/run/wpa_supplicant
	echo 'ctrl_interface=/var/run/wpa_supplicant' > /etc/wpa_supplicant.conf
	wpa_supplicant -i$WLAN -B -D$DRIVER -c/etc/wpa_supplicant.conf
}
################################################################################
wpa_supplicant_stop ()
{
	echo -e $RED'stop wpa_supplicant.'$NORMAL
	wpa_cli -i$WLAN terminate
}
################################################################################
run ()
{
	cmd=$1
	echo -ne "$cmd - "`eval $cmd`"\n"
}
################################################################################
wait_connect ()
{
	ix=0
	TRYTIMES=20
	echo -ne "connect "
	while [ $ix -lt $TRYTIMES ]; do
		MSG=`wpa_cli -i$WLAN status | grep -r "wpa_state=COMPLETED"`
		if [ ss"$MSG" = ss"" ]; then
			sleep 1s
			ix=$(($ix+1))
			echo -ne "."
		else
			echo " ok"
			return 0
		fi
	done
	echo " timeout"
	return 1
}
################################################################################
wifi_sta_connect ()
{
	REL=1
	echo -e $RED'prepare connect wifi ap.'$NORMAL
	wpa_cli -i$WLAN disable_network all > /dev/null

	run "wpa_cli -i$WLAN remove_network all"
	ifconfig $WLAN down
	ifconfig $WLAN up

	case "$SECURITY" in
	"WPAPSK" )
		wifi_sta_security_wpa_psk
		REL=$?
	;;
	"WEP" )
		wifi_sta_security_wep
		REL=$?
	;;
	"NONE" )
		wifi_sta_security_none
		REL=$?
	;;
	* )
		echo "Not recognise security mode"
		echo "SECURITY=$SECURITY"
		REL=1
	;;
	esac

	if [ "$REL" = "1" ]; then
		echo -e $RED'connect wifi ap fail.'$NORMAL
		wpa_cli -i$WLAN status
		wpa_cli -i$WLAN remove_network all >/dev/null 2>&1
		ifconfig $WLAN down
		return 1
	else
		echo -e $RED'connect wifi ap success.'$NORMAL
		wpa_cli -i$WLAN status
		return 0
	fi

}
################################################################################
# no password
wifi_sta_security_none ()
{
	NETWORK_ID=`wpa_cli -i$WLAN add_network`
	run "wpa_cli -i$WLAN set_network $NETWORK_ID ssid '\"$SSID\"'"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID key_mgmt NONE"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID scan_ssid 1"
	run "wpa_cli -i$WLAN enable_network $NETWORK_ID"
	wait_connect
	return $?
}
################################################################################
# wep
wifi_sta_security_wep ()
{
	PWD_LEN=`echo "$PASSWORD" | awk '{print length($0)}'`
	NETWORK_ID=`wpa_cli -i$WLAN add_network`
	run "wpa_cli -i$WLAN set_network $NETWORK_ID ssid '\"$SSID\"'"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID key_mgmt NONE"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID scan_ssid 1"
	if [ $PWD_LEN = 5 -o $PWD_LEN = 13 ];then
		run "wpa_cli -i$WLAN set_network $NETWORK_ID wep_key0 '\"$PASSWORD\"'"
	elif [ $PWD_LEN = 10 -o $PWD_LEN = 26 ];then
		run "wpa_cli -i$WLAN set_network $NETWORK_ID wep_key0 '$PASSWORD'"
	else
		echo "Password length is wrong!"
	fi
	run "wpa_cli -i$WLAN enable_network $NETWORK_ID"
	wait_connect
	return $?
}
################################################################################
# wpa-psk
wifi_sta_security_wpa_psk ()
{
	NETWORK_ID=`wpa_cli -i$WLAN add_network`
	run "wpa_cli -i$WLAN set_network $NETWORK_ID scan_ssid 1"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID ssid '\"$SSID\"'"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID proto 'WPA RSN'"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID key_mgmt WPA-PSK"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID pairwise 'CCMP TKIP'"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID group 'CCMP TKIP'"
	run "wpa_cli -i$WLAN set_network $NETWORK_ID psk '\"$PASSWORD\"'"
	run "wpa_cli -i$WLAN enable_network $NETWORK_ID"
	wait_connect
	return $?
}
################################################################################

echo "=========================================================="
echo "WLAN     =$WLAN"
echo "SSID     =$SSID"
echo "PASSWORD =$PASSWORD"
echo "SECURITY =$SECURITY"
echo "=========================================================="

wpa_supplicant_start
wifi_sta_connect

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值