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](

### Android WIFI 配置与连接的技术解析 #### 1. Android WIFI 配置流程 在 Android 中,WIFI 的配置主要依赖于 `WifiManager` 类。通过该类可以完成网络的添加、移除以及状态监控等功能。以下是关于如何配置并连接到指定 WIFI 网络的关键步骤: - **创建 WIFI 配置对象** 使用 `WifiConfiguration` 对象来定义目标 WIFI 网络的信息,例如 SSID 和密码。 ```java WifiConfiguration config = new WifiConfiguration(); config.SSID = "\"" + ssid + "\""; // 注意 SSID 必须加双引号 config.preSharedKey = "\"" + password + "\""; ``` - **添加网络配置** 调用 `addNetwork()` 方法将新配置加入系统,并返回一个整数 ID 表示此配置项。 ```java int networkId = wifiManager.addNetwork(config); if (networkId == -1) { throw new Exception("Failed to add network configuration."); } ``` - **启用特定网络配置** 利用 `enableNetwork(networkId, true)` 启动刚刚添加的网络配置。 ```java boolean isEnabled = wifiManager.enableNetwork(networkId, true); if (!isEnabled) { throw new Exception("Failed to enable the specified network."); } ``` 以上操作完成后,需监听广播事件 `"WifiManager.NETWORK_STATE_CHANGED_ACTION"` 来确认是否成功连接至目标 WIFI[^1]。 --- #### 2. 删除当前已连接的 WIFI 配置信息 针对 Android 9.0 及更高版本,删除现有 WIFI 配置的功能被进一步优化。核心逻辑涉及调用 `removeNetwork(int netId)` 方法以清除指定网络条目,并最终通知系统刷新可用列表。 具体实现如下所示: ```java // 获取当前活动网络的 ID int currentNetId = getCurrentNetworkId(wifiManager); if (currentNetId != -1 && wifiManager.removeNetwork(currentNetId)) { Log.d(TAG, "Successfully removed the active network with ID: " + currentNetId); } else { Log.e(TAG, "Failed to remove the active network or no valid ID found."); } private int getCurrentNetworkId(WifiManager wifiManager) { List<WifiConfiguration> configuredNetworks = wifiManager.getConfiguredNetworks(); if (configuredNetworks != null) { for (WifiConfiguration config : configuredNetworks) { if (config.networkId >= 0 && wifiManager.getConnectionInfo().getNetworkId() == config.networkId) { return config.networkId; } } } return -1; // 如果未找到匹配的网络,则返回默认值 -1 } ``` 上述代码片段展示了如何定位当前正在使用的网络及其对应的唯一标识符(netId),随后执行移除动作[^2]。 --- #### 3. 实现动态检测 WIFI 是否处于连接状态 为了实时掌握设备的联网状况,可借助 `ConnectivityManager` 提供的服务接口查询活跃网络的状态。下面是一段用于验证 WIFI 是否正常工作的辅助函数: ```java public boolean isWifiConnected(Context context) { ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); NetworkCapabilities capabilities; if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { Network network = connectivityManager.getActiveNetwork(); capabilities = connectivityManager.getNetworkCapabilities(network); return capabilities != null && (capabilities.hasTransport(NetworkCapabilities.TRANSPORT_WIFI)); } else { @SuppressWarnings("deprecation") NetworkInfo info = connectivityManager.getActiveNetworkInfo(); return info != null && info.getType() == ConnectivityManager.TYPE_WIFI && info.isConnected(); } } ``` 这段程序兼容旧版 API 并支持现代化特性,能够适应不同平台环境下的需求变化[^4]。 --- #### 4. 关键服务组件剖析 深入研究底层架构可知,AndroidWIFI 功能由多个模块协同工作共同维护其运行机制。其中部分重要文件包括但不限于以下几个方面: - `SupplicantStaNetworkHalAidlImpl.java`: 定义了 STA 模式的 HAL 接口规范; - `SupplicantStaNetworkCallbackAidlImpl.java`: 处理来自 supplicant 层面的通知回调消息处理逻辑; 这些源码文档揭示了更深层次的操作细节和技术原理[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

峥嵘life

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

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

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

打赏作者

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

抵扣说明:

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

余额充值