欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Android Oreo8.0 使用wpa_supplicant和wpa_cli(更新AndroidPie9.0)

程序员文章站 2022-07-01 10:55:49
...

使用wpa_cli关键是先启动wpa_supplicant,而启动wpa_supplicant关键是要指定好启动参数,文件路径要对。

 

  • 启动WLAN

(1)加载驱动 
android系统需要先load driver。手动调试dirver ko的时候,先调用insmod命令加载指定的wifi驱动。 

再调用iwconfig可以看到驱动是否加载成功,如下,可以看到wlan0已经有了,则驱动加载成功。

# ifconfig -a

p2p0      Link encap:Ethernet  HWaddr b2:72:bf:d9:55:9f  Driver hif_pci
          BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:3000
          RX bytes:0 TX bytes:0


wlan0     Link encap:Ethernet  HWaddr b0:72:bf:53:55:9f  Driver hif_pci
          UP BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:3000
          RX bytes:0 TX bytes:0


lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope: Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1
          RX bytes:0 TX bytes:0


sit0      Link encap:IPv6-in-IPv4
          NOARP  MTU:1480  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1
          RX bytes:0 TX bytes:0


eth0      Link encap:Ethernet  HWaddr 00:04:9f:05:58:c7  Driver fec
          UP BROADCAST MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:0 TX bytes:0

(2)打开wlan0 
            ifconfig wlan0 up

 

 

  • 启动wpa_supplicant

命令如下:可以参考下自己init.xxx.rc是如何配置的,参数可能会不一样。

/vendor/bin/hw/wpa_supplicant -d -B –iwlan0 –Dnl80211 -c/data/misc/wifi/wpa_supplicant.conf 
 -C/data/misc/wifi/sockets

-i:指定网口; 

-D:指定驱动类型; 

-c:指定了wpa_supplicant的配置文件。

-C : ctrl_interface parameter 

配置文件/data/misc/wifi/wpa_supplicant.conf,-d参数是打开wpa_supplicant的打印。

这里AndroidPie9.0 改变了wpa_supplicant.conf ctrl_interface 的路径:

我这边是改为了/vendor/etc/wifi/wpa_supplicant.conf   和   /data/vendor/wifi/wpa/sockets


所以能正确启动wpa_supplicant的关键就是这边要指定正确的参数路径。

然后确保wpa_supplicant已经运行起来了,可以ps -A | grep wpa看下。

console:/ # ps -A | grep wpa
wifi          4100     1   18316   4904 poll_schedule_timeout 0 S wpa_supplicant
 

  • 启动wpa_cli
wpa_cli -i网口 -p socket所在路径

例如像我刚才那么调用的话,则用下面命令启动:

wpa_cli -iwlan0 -p /data/misc/wifi/sockets/

进入如下界面则已经可以正常调试了。

wpa_cli v2.0-devel-4.4.2_rtw_r12456.20141113_beta
Copyright (c) 2004-2013, Jouni Malinen <[email protected]> and contributors

This software may be distributed under the terms of the BSD license.
See README for more details.



Interactive mode

> 

如果一直显示如果出现“Could not connect to wpa_supplicant - re-trying”,那表示 wpa_cli 不能和wpa_supplicant 建立 socket 连接,这时要检查 wpa_supplicant 进程是否还在,还有socket所在路径wlan0是否存在(在我的例子是/data/misc/wifi/sockets/wlan0)。

 

 

  • 使用wpa_cli 进行debug 

扫描ap

输入scan命令

> scan
OK
<3>CTRL-EVENT-STATE-CHANGE id=-1 state=3 BSSID=00:00:00:00:00:00 SSID=
<3>CTRL-EVENT-SCAN-RESULTS 
<3>CTRL-EVENT-STATE-CHANGE id=-1 state=0 BSSID=00:00:00:00:00:00 SSID=
> 

 

wpa_supplicant有“CTRL-EVENT-SCAN-RESULTS ”的回复,则可以输入scan_results可以看到扫描结果,如下。

 

> scan_results
bssid / frequency / signal level / flags / ssid
14:75:90:7b:9c:b2       5745    -52     [WPA-PSK-CCMP][WPA2-PSK-CCMP][ESS]      TP-LINK_5G_9CB2
a0:63:91:45:9a:ed       5785    -63     [WPA2-PSK-CCMP][WPS][ESS]       LinuxBSPtest_5G
a4:6c:2a:54:03:d7       5765    -57     [WPA2-EAP-CCMP][ESS]    NXP
a4:6c:2a:54:03:db       5765    -58     [WPA-PSK-TKIP][WPA2-PSK-CCMP][ESS]      External-Internet
a4:6c:2a:54:03:df       5765    -58     [WPA2-EAP-CCMP][ESS]    Freescale
a4:6c:2a:54:03:d8       5765    -58     [WPA2-PSK-CCMP][ESS]    Hydra
d4:ee:07:50:a8:52       2447    -50     [WPA-PSK-CCMP][WPA2-PSK-CCMP][ESS]      Android_test

 

连接

 

从扫描结果选择连接一个ap。

> add_network 
1
> set_network 1 ssid "HUAWEI G9 Youth"
OK
> set_network 1 key_mgmt WPA-PSK 
OK
> set_network 1 psk "xx123456"   
OK
> set_network 1 pairwise CCMP 
OK
> set_network 1 group CCMP   
OK
> set_network 1 proto WPA2
OK
> enable_network 1
OK
<3>CTRL-EVENT-STATE-CHANGE id=-1 state=3 BSSID=00:00:00:00:00:00 SSID=
<3>CTRL-EVENT-SCAN-RESULTS 
<3>WPS-AP-AVAILABLE 
<3>Trying to associate with d4:61:2e:a2:b9:e5 (SSID='HUAWEI G9 Youth' freq=2437 MHz)
<3>CTRL-EVENT-STATE-CHANGE id=-1 state=5 BSSID=00:00:00:00:00:00 SSID=
<3>CTRL-EVENT-STATE-CHANGE id=1 state=6 BSSID=00:00:00:00:00:00 SSID=HUAWEI G9 Youth
<3>Associated with d4:61:2e:a2:b9:e5
<3>CTRL-EVENT-STATE-CHANGE id=1 state=7 BSSID=d4:61:2e:a2:b9:e5 SSID=HUAWEI G9 Youth
<3>CTRL-EVENT-STATE-CHANGE id=1 state=8 BSSID=d4:61:2e:a2:b9:e5 SSID=HUAWEI G9 Youth
<3>WPA: Key negotiation completed with d4:61:2e:a2:b9:e5 [PTK=CCMP GTK=CCMP]
<3>CTRL-EVENT-CONNECTED - Connection to d4:61:2e:a2:b9:e5 completed (auth) [id=1 id_str=]
<3>CTRL-EVENT-STATE-CHANGE id=1 state=9 BSSID=d4:61:2e:a2:b9:e5 SSID=HUAWEI G9 Youth

 

步骤如下: 
(1)“add_network”,这里返回网络ID 为 1。 
(2) 配置网络的 SSID,执行 set_network 1 ssid AP 的 SSID。 
(3)配置网络的加密方式和密码。 
(4)启动网络,执行“enable_network 0”。 
(5)收到“CTRL-EVENT-CONNECTED”表示连接成功。

 

分配IP

此时已经连接上ap,dhcp分配一个IP即可。 

输入 q 退出 wpa_cli,执行命令:dhcpcd wlan0 

此时已经可以ping通了。