当前位置: 首页 > news >正文

Android wifi开发调试总结

Android wifi开发调试简单总结

文章目录

  • Android wifi开发调试简单总结
    • 一、前言
    • 二、wifi demo开发
      • 1、开关和连接
      • 2、wifi开启主要流程
      • 3 、wifi主要广播
      • 4、相关日志
      • 5、demo示例
    • 三、其他
      • 1、Wifi开发小结
      • 2、其他wifi知识小结
        • (1)Android无线Wifi开发
        • (2)Android13 Wifi启动流程分析
        • (3)Android 使用adb操作WiFi连接扫描等相关指令
        • (4)Android10 系统应用wifi连接和静态ip代理设置
        • (5)Android 获取ip地址多种方式介绍

一、前言

如果开发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](

相关文章:

  • NIPS2021 | 视觉 Transformer 的有趣特性
  • 华纳云:centos如何实现JSP页面的动态加载
  • Oracle的PLSQL中动态执行函数
  • Ubuntu中C++项目安装二次规划库——qpOASES 库
  • 基于STM32、HAL库的DS2411R安全验证及加密芯片驱动程序设计
  • HarmonyOS NEXT 诗词元服务项目开发上架全流程实战(一、项目介绍及实现效果展示)
  • 蓝桥杯Python组高频考点与解题策略
  • Axios 传参与 Spring Boot 接收参数完全指南
  • Visual Studio 技能:调整软件界面布局
  • SoapUi测试1——REST(WebAPi、Json协议/HTTP、Post通讯方式)接口测试
  • C语言基础—(函数,指针与形参实参,字符串与指针,结构体)
  • 在另外一台可以科学下载的电脑用ollama下载模型后,怎么导入到另外一台服务器的ollama使用
  • (一)Linux的历史与环境搭建
  • 云原生--核心组件-容器篇-6-Docker核心之-镜像仓库(公共仓库,私有仓库,第三方仓库)
  • 香橙派打包qt文件报错“xcb 插件无法加载”与“QObject::moveToThread”线程错误的解决方案
  • 2.2.1goweb内置的 HTTP 处理程序
  • uniapp做app,使用v-for遍历渲染第二层的时候,打包到手机上渲染不出第二层的数据
  • 5G与边缘计算:协同发展,开启智慧世界新篇章
  • (云计算HCIP)HCIP全笔记(十三)本篇介绍虚拟化技术,内容包含:虚拟化资源、虚拟化过程、I/O虚拟化、虚拟化架构KVM和Xen介绍、主流虚拟化技术介绍
  • 终端管理系统如何助力企业简化IT管理?
  • 国家核准10台核电新机组,四大核电央企披露新项目进展
  • 伊朗港口爆炸已致40人死亡
  • 湖南小伙“朱雀玄武敕令”提交申请改名为“朱咸宁”
  • 中青报:“猿辅导员工猝死”事件上热搜,是对健康职场环境的共同关切
  • 交警不在就闯红灯?上海公安用科技手段查处非机动车违法
  • 博物馆有一项活动40岁以上不能参加?馆方回应