Android wifi开发调试总结

Android wifi开发调试简单总结

一、前言

如果开发wifi相关功能,必须先掌握基本api知识和相关广播的监听;

wifi调用的功能基本都是系统签名权限的系统应用,比如Settings;

本简单介绍wifi开发基本知识,有兴趣的可以看看。

二、wifi demo开发

1、开关和连接

//开关
WifiManager wifiManager = (WifiManager) mActivity.getSystemService(Context.WIFI_SERVICE);
wifiManager.setWifiEnabled(isChecked); //true、false参数表示开关

//其中一种系统应用连接方式,WifiConfiguration对象包含wifi名称,密码类型和密码
WifiManager.connect(WifiConfiguration, mConnectListener);

//第二种是普通应用的连接方式:
int wcgId = wifiManager.addNetwork(configuration);
wifiManager.enableNetwork(wcgId, true);

2、wifi开启主要流程

相关类的调用:

正常开关wifi 启动流程:
1、WifiManager.setWifiEnabled
2、WifiServiceImpl
3、ActiveModeWarden
4、ConcreteClientModeManager
5、WifiNative
6、WifiVendorHal
7、HalDeviceManager
8、wifi.cpp

3 、wifi主要广播

相关广播如下:

ConnectivityManager.CONNECTIVITY_ACTION:网络ip变化广播
WifiManager.WIFI_STATE_CHANGED_ACTION :wifi开关变化广播
WifiManager.NETWORK_STATE_CHANGED_ACTION :wifi网络变化广播
WifiManager.SUPPLICANT_STATE_CHANGED_ACTION :wifi连接验证过程变化广播
WifiManager.SUPPLICANT_CONNECTION_CHANGE_ACTION :wifi开关变化广播
WifiManager.SCAN_RESULTS_AVAILABLE_ACTION//扫描到wifi广播

4、相关日志

Wifi相关日志的关键字都是:wifi,会有点多
wifi开关的日志是:WifiService
底层相关日志:wpa_supplicant、wifi-service
其他相关:WifiNative、WifiHAL

日志过滤:
logcat | grep -i wifi
logcat | grep -iE "WifiService|WifiNative"
logcat | grep -iE "WifiService|wpa_supplicant|wifi-service|WifiNative|WifiHAL|DHCP|wlan"

wifi开启的上层日志:

logcat | grep -iE "WifiService|WifiNative"
04-26 15:19:19.059   821  1536 I WifiService: setWifiEnabled package=com.skg.settings uid=1000 enable=true isPrivileged=true //开启日志,包含开启的应用包名
04-26 15:19:19.112   821  1030 I WifiNative: Interface state changed on Iface:{Name=wlan0,Id=5,Type=STA_SCAN}, isUp=true
04-26 15:19:19.113   821  1030 I WifiNative: Successfully setup Iface:{Name=wlan0,Id=5,Type=STA_SCAN}
04-26 15:19:19.284   821  1030 I WifiNative: Successfully switched to connectivity mode on iface=Iface:{Name=wlan0,Id=5,Type=STA_CONNECTIVITY}
04-26 15:19:19.299   821  1030 D WifiNative: onSetCountryCodeSucceeded: US //countryCode
04-26 15:19:19.322   821  1443 I WifiService: startScan uid=1000 //扫描wifi
04-26 15:19:23.480   821  1443 D WifiNative: Scan result ready event //获取到wifi列表

这里只是wifi的部分上层开启日志,开启完成大概300多秒。

底层相关的日志非常多。

有些底层报错的error日志,正常开启也会存在,有些是不存在的;

所以wifi开启异常的情况需要对比异常和正常的日志,

确定是底层的关键报错信息后可以让底层驱动工程师先分析,比如设备节点not found/unload。

新方案更做的时候wifi正常开启也可以看到很多底层打印的异常日志,比如3588 Android15.

5、demo示例

图片效果如下:
在这里插入图片描述

主要功能:wifi开关控制,扫描并显示wifi列,获取已保存的wifi列表(点击重连,长按忘记),添加网络;

监听wifi开关和连接变化后,更新wifi基本信息。

后续提供了apk的源码和 3588 AN14 、311D2 AN13 签名的Demo apk;

如果不想重新编译apk,可以放到源码中,替换之前某个apk,重新编译也会生成对应系统签名的apk。

这里显示的是wifi的最原生加密类型字符串描述符,wifi封装类中wifi加密类型的判断逻辑大致是:

如果描述符包含EAP,就是企业网络;
如果包含SAE,就是WPA3网络;
如果包含WPA2,就是WPA2 网络;(绝大部分wifi的加密类型)
如果包含WPA,就是WPA 网络;
如果都没有就是,无加密模式。
还有一些加密类型是不常用的。

源码下载地址:

https://download.csdn.net/download/wenzhi20102321/90713713

三、其他

1、Wifi开发小结

(1)wifi相关接口的调用一般要系统签名权限,所以开发wifi基本都是系统应用;
(2)普通也可以startActivity到Settings应用进行一些处理;
(3)系统Settings应用对wifi的列表获取和接口调用基本都是使用SettingsLib的接口;
(4)比如需要wifi是否连接,通过wifi扫描到的列表对象或者wifi已保存的列表对象就没有判断已连接的方法;
(5)SettingsLib获取的列表对象AccessPoint就有很多封装方法,可以判断当前wifi是否连接状态;

2、其他wifi知识小结

(1)Android无线Wifi开发

早期的普通应用开发wifi知识:

https://blog.csdn.net/wenzhi20102321/article/details/53871216

(2)Android13 Wifi启动流程分析

如果遇到wifi 打不开问题,可以依照这个流程进行分析,看看具体是哪个流程出现问题:

https://blog.csdn.net/wenzhi20102321/article/details/135139360

(3)Android 使用adb操作WiFi连接扫描等相关指令

wifi开关调试最常用的就是 svc wifi enable/disable,或者使用iv dev来验证,

但对于AP功能就没办法验证了,并且可调试功能比较少,

其实Android系统自带有组很强大的shell指令集,比如:

adb shell cmd wifi set-wifi-enabled enabled //开启wifi
adb shell cmd wifi set-wifi-enabled disabled
adb shell cmd wifi start-scan             //扫描
adb shell cmd wifi list-scan-results    //查看扫描结果

这里记录下平时使用的cmd wifi 相关指令:

https://blog.csdn.net/wenzhi20102321/article/details/140043930

(4)Android10 系统应用wifi连接和静态ip代理设置

Android wifi连接和静态ip代理设置 主要针对系统应用:

https://blog.csdn.net/wenzhi20102321/article/details/123675077

(5)Android 获取ip地址多种方式介绍

adb shell 的 ifconfig可以获取当前设备网络节点信息;
这些信息使用Android代码也是可以获取的;

Android 获取网络ip有多种方式,有时候某种方式获取失败的情况下;
那么就可以换一种获取方式,所有多学习一下获取网络ip相关信息是有用的:

[https://blog.csdn.net/wenzhi20102321/article/details/141673195](

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

峥嵘life

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值