当前位置:   article > 正文

Android-WiFi开发之 WifiManager_android wifimanager最新

android wifimanager最新

前言:
在初始涉足Android系统开发时, 对于WiFi是一个门外汉; 逐渐开始接触做系统应用, 开始整理WiFi相关的知识点, 今天更新一下WiFi的管理类 ------> WifiManager;

一. 简介:
WifiManager这个类, 是 Android 暴露给开发者使用的一个系统服务管理类, 其中包含对WiFi的响应的操作函数; 其隐藏掉的系统服务类为IWifiService, 为Android私有的, 其具体实现, 未暴露给用户; 只需要使用WifiManager进行函数操作完成UI, 监听对应的广播消息, 就可完成功能了. 换言之, WifiManager会调用service简介地和framework层, 驱动层进行函数调用, 然后驱动层会回调至上层, 以广播的形式实现通知; 这是目前WiFi的简单介绍;

二. 一些简单的WiFi操作以及简要说明:
<1> 获取 WifiManager 实例:
WifiManager wifiManager = (WifiManager) context.getSystemService(Context.WIFI_SERVICE);

  1. 注意:
  2. 这是官方推荐的获取 WifiManager 类的方式; 其实在看源码的时候, 会有一个公共的构造函数, 但是是需要IWifiService的, 这个类是google私有的,
  3. 属于系统安全级别的API类, 所以, 调用上面的方法, 谷歌会帮你实例化IWifiService, 并且后续的连接, 忘记, 保存的真实实现都是由service来完成的;
  4. <2> 开启, 关闭 WiFi:
  5. wifiManager.setWifiEnabled(boolean enable); 操作这个函数的时候, 就会触发系统回调WiFi状态发生改变的广播;
  6. <3> 获取 WiFi 硬件的状态:
  7. int wifiState = wifiManager.getWifiState();
  8. 注意:
  9. WiFi 的状态目前有五种, 分别是:
  10. WifiManager.WIFI_STATE_ENABLING: WiFi正要开启的状态, 是 Enabled 和 Disabled 的临界状态;
  11. WifiManager.WIFI_STATE_ENABLED: WiFi已经完全开启的状态;
  12. WifiManager.WIFI_STATE_DISABLING: WiFi正要关闭的状态, 是 Disabled 和 Enabled 的临界状态;
  13. WifiManager.WIFI_STATE_DISABLED: WiFi已经完全关闭的状态;
  14. WifiManager.WIFI_STATE_UNKNOWN: WiFi未知的状态, WiFi开启, 关闭过程中出现异常, 或是厂家未配备WiFi外挂模块会出现的情况;
  15. <4> 开始扫描 WiFi 热点:
  16. 在确认开启 WiFi 之后, 我们就可以调用 startScan() 函数开始扫描附近的热点了, 即:
  17. wifiManager.startScan();
  18. <5> 获取扫描到的 WiFi 热点的结果:
  19. List<ScanResult> scanResults = wifiManager.getScanResult();
  20. 然后, 我们看一下扫描到的结果是一个怎么样的构成?
  21. if (scanResults == null || scanResults.isEmpty()) return;
  22. for (ScanResult result : scanResults) {
  23. Log.v(TAG, "result = " + result.toString())
  24. }
  25. <6> 获取配置好的 WiFi 信息:
  26. List<WifiConfiguration> wifiConfigurations = wifiManager.getConfiguredNetworks();
  27. 然后, 我们看一下扫描到的结果是一个怎么样的构成?
  28. if (wifiConfigurations == null || wifiConfigurations.isEmpty()) return;
  29. for (WifiConfiguration configuration : wifiConfigurations) {
  30. Log.v(TAG, "configuration = " + configuration.toString());
  31. }
  32. 注意:
  33. Android 的 WiFi 连接, 大概可以分为如下两种情况:
  34. a. 无密码的, 可直接连接, 连接过程中, 此热点一直有, 不管最后是否需要其他方式进行验证操作, 但凡连接成功, 即刻进行了对此热点的配置进行保存;
  35. b. 有密码的, 暂且不论何种加密手段, 只要用户输入密码, 点击连接, 如果连接途中, 此热点一直有, 不论连接成功还是失败, 都即刻对此热点的配置进行了保存操作;
  36. 使用上述的方式获取到的WiFi的配置, 就是上面进行操作保存的WiFi配置;
  37. c. 连接多个WiFi成功之后, 然后关闭WiFi, 下次开启WiFi的时候, 它会主动帮你连接这其中配置好的其中一个WiFi;
  38. <7> 获取对应到ScanResult的WifiConfiguration, 通常, 此配置对应一个BSSID, 可能是null;
  39. List<WifiConfiguration> configs = wifiManager.getMatchingWifiConfig(scanResult);
  40. 可以打印一下看具体的情况:
  41. if (configs == null || configs.isEmpty()) return;
  42. for (WifiConfiguration config : configs) {
  43. Log.v(TAG, "config = " + config);
  44. }
  45. <8> 连接WiFi, 有两个函数:
  46. wifiManager.connect(WifiConfiguration config, ActionListener listener); 其中包含两个参数: 第一个是WifiConfiguration, 如果是之前连接过得, 是可以直接连接的;
  47. 否则需要进行手动进行组合(无密码的除外); 第二个参数是ActionListener, 是WifiManager中的hide的接口, 是连接过程的状态回调; 包含 onSuccess() 和 onFailure(int reason);
  48. wifiManager.connect(int networkId, ActionListener listener); 其中包含两个参数: 第一个是只需传入networkId, Android使用这个参数, 对请求连接的WiFi进行识别鉴定;
  49. 第二个参数同上, 可以传null

暂时先更新至此, 会尽快更新



作者:迷你小猪
链接:https://www.jianshu.com/p/67aaf1fdb921
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/295531
推荐阅读
相关标签
  

闽ICP备14008679号