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

Android WIFI工具类 特别兼容Android12

直接上代码:

package com.realtop.commonutils.utils;import android.annotation.SuppressLint;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothManager;
import android.bluetooth.BluetoothProfile;
import android.content.Context;
import android.net.IpConfiguration;
import android.net.wifi.WifiConfiguration;
import android.net.wifi.WifiEnterpriseConfig;
import android.net.wifi.WifiInfo;
import android.net.wifi.WifiManager;
import android.os.Build;
import android.text.TextUtils;
import android.util.Log;import java.util.ArrayList;
import java.util.List;public class WIFIHelper {public static final String TAG = "wifi_utils";public static String getForgetName(WifiManager manager) {WifiInfo connectionInfo = manager.getConnectionInfo();String ssid = connectionInfo.getSSID().replace("\"", "");return ssid;}public static void forgetNetwork(WifiManager manager) {try {WifiInfo connectionInfo = manager.getConnectionInfo();String ssid = connectionInfo.getSSID().replace("\"", "");int networkId = connectionInfo.getNetworkId();Log.i(TAG, "forgetNetwork: enter:" + ssid + "; " + networkId);manager.forget(networkId, new WifiManager.ActionListener() {@Overridepublic void onSuccess() {Log.i(TAG, "forgetNetwork: onSuccess: is ok");manager.removeNetwork(networkId);}@Overridepublic void onFailure(int reason) {Log.i(TAG, "forgetNetwork: onFailure: reason:" + reason);manager.removeNetwork(networkId);}});ComUtils.saveString(ComConfig.WIFI_PWD_PRE + ssid, "");Log.i(TAG, "forgetNetwork: remove id:" + networkId + ";" + ssid);} catch (Exception e) {e.printStackTrace();Log.i(TAG, "forgetNetwork: error:" + e.getMessage());}}/*** 连接wifi** @param manager       WifiManager* @param configuration Wifi配置* @return 是否连接成功*/public static boolean connectWifi(WifiManager manager, WifiConfiguration configuration) {Log.i(TAG, "connectWifi: enter");manager.connect(configuration, new WifiManager.ActionListener() {@Overridepublic void onSuccess() {Log.i(TAG, "connectWifi: onSuccess: connect ok");}@Overridepublic void onFailure(int reason) {Log.i(TAG, "connectWifi: onFailure: error:" + reason);}});return true;}/*** 创建Wifi配置** @param SSID         wifi名称* @param password     wifi密码* @param hidden       网络是否隐藏(该方法与添加隐藏网络通用)* @param capabilities 网络安全协议* @return 配置好的wifi*/public static WifiConfiguration createWifiInfo(String SSID, String password, boolean hidden, String capabilities) {WifiConfiguration configuration = new WifiConfiguration();configuration.SSID = "\"" + SSID + "\"";if (hidden) {configuration.hiddenSSID = true;}Log.d("WifiManagerUtils", "createWifiInfo: " + capabilities);if (capabilities.contains("SAE") && Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {setWPA3(configuration, password);} else if (capabilities.contains("WPA-PSK") || capabilities.contains("WPA2-PSK")) {setWPA(configuration, password);} else if (capabilities.contains("WEP")) {setWEP(configuration, password);} else {setESS(configuration);}return configuration;}@SuppressLint("NewApi")public static WifiConfiguration createWifiConfiguration(String SSID, String password, boolean hidden, String capabilities) {WifiConfiguration config = new WifiConfiguration();config.SSID = "\"" + SSID + "\"";config.hiddenSSID = hidden;config.shared = false;Log.d("WifiManagerUtils", "createWifiInfo: " + capabilities);// 分别适配安全类型if (capabilities.contains("SAE")) {config.setSecurityParams(WifiConfiguration.SECURITY_TYPE_SAE);if (!TextUtils.isEmpty(password)) {config.preSharedKey = '"' + password + '"';}Log.i(TAG, "createWifiConfiguration: sae");} else if (capabilities.contains("WPA-PSK") || capabilities.contains("WPA2-PSK")) {config.setSecurityParams(WifiConfiguration.SECURITY_TYPE_PSK);if (!TextUtils.isEmpty(password)) {if (password.matches("[0-9A-Fa-f]{64}")) {config.preSharedKey = password;} else {config.preSharedKey = '"' + password + '"';}}Log.i(TAG, "createWifiConfiguration: psk");} else if (capabilities.contains("WEP")) {config.setSecurityParams(WifiConfiguration.SECURITY_TYPE_WEP);if (!TextUtils.isEmpty(password)) {int length = password.length();// WEP-40, WEP-104, and 256-bit WEP (WEP-232?)if ((length == 10 || length == 26 || length == 58)&& password.matches("[0-9A-Fa-f]*")) {config.wepKeys[0] = password;} else {config.wepKeys[0] = '"' + password + '"';}}Log.i(TAG, "createWifiConfiguration: wep");} else if (capabilities.contains("OWE")) {config.setSecurityParams(WifiConfiguration.SECURITY_TYPE_OWE);Log.i(TAG, "createWifiConfiguration: owe");} else if (capabilities.contains("EAP")) {setEAP(config, password);Log.i(TAG, "createWifiConfiguration: eap");} else {// 无密码config.setSecurityParams(WifiConfiguration.SECURITY_TYPE_OPEN);config.shared = true;Log.i(TAG, "createWifiConfiguration: open");}final IpConfiguration ipConfig = new IpConfiguration();ipConfig.setIpAssignment(IpConfiguration.IpAssignment.UNASSIGNED);ipConfig.setProxySettings(IpConfiguration.ProxySettings.UNASSIGNED);ipConfig.setStaticIpConfiguration(null);ipConfig.setHttpProxy(null);config.setIpConfiguration(ipConfig);return config;}private static void setEAP(WifiConfiguration wifiConfig, String password) {// 设置身份验证类型为 EAPwifiConfig.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_EAP);// 设置 EAP 方法(这是具体的 EAP 身份验证类型)wifiConfig.enterpriseConfig.setEapMethod(-1);// 设置身份验证用户名和密码wifiConfig.enterpriseConfig.setIdentity("");wifiConfig.enterpriseConfig.setPassword(password);}/*** 设置wpa3协议** @param configuration 配置* @param password      密码*/public static void setWPA3(WifiConfiguration configuration, String password) {if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {configuration.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.SAE);}configuration.preSharedKey = "\"" + password + "\"";}/*** WPA协议** @param configuration 配置* @param password      密码*/public static void setWPA(WifiConfiguration configuration, String password) {configuration.preSharedKey = "\"" + password + "\"";//公认的IEEE 802.11验证算法。configuration.allowedAuthAlgorithms.clear();configuration.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.OPEN);//公认的的公共组密码。configuration.allowedGroupCiphers.clear();configuration.allowedGroupCiphers.set(WifiConfiguration.PairwiseCipher.CCMP);configuration.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.TKIP);//公认的密钥管理方案。configuration.allowedKeyManagement.clear();configuration.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_PSK);//密码为WPA。configuration.allowedPairwiseCiphers.clear();configuration.allowedPairwiseCiphers.set(WifiConfiguration.PairwiseCipher.CCMP);configuration.allowedPairwiseCiphers.set(WifiConfiguration.PairwiseCipher.TKIP);//公认的安全协议。configuration.allowedProtocols.clear();configuration.allowedProtocols.set(WifiConfiguration.Protocol.RSN);}/*** WEP协议** @param configuration 配置* @param password      密码*/public static void setWEP(WifiConfiguration configuration, String password) {configuration.wepKeys[0] = "\"" + password + "\"";configuration.wepTxKeyIndex = 0;configuration.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.NONE);configuration.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.WEP40);}/*** 无密码** @param configuration 配置*/public static void setESS(WifiConfiguration configuration) {configuration.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.NONE);}public static List<BluetoothDevice> getBlueConnectDevices() {BluetoothManager bluetoothManager = (BluetoothManager) EventBusHelper.getContext().getSystemService(Context.BLUETOOTH_SERVICE);@SuppressLint("MissingPermission")List<BluetoothDevice> connectedDevices = bluetoothManager.getConnectedDevices(BluetoothProfile.GATT);if (connectedDevices != null) {return connectedDevices;} else {return new ArrayList<>();}}
}

相关文章:

Android WIFI工具类 特别兼容Android12

直接上代码&#xff1a; package com.realtop.commonutils.utils;import android.annotation.SuppressLint; import android.bluetooth.BluetoothDevice; import android.bluetooth.BluetoothManager; import android.bluetooth.BluetoothProfile; import android.content.Con…...

【Android Framework系列】第14章 Fragment核心原理(AndroidX版本)

1 简介 Fragment是一个历史悠久的组件&#xff0c;从API 11引入至今&#xff0c;已经成为Android开发中最常用的组件之一。 Fragment表示应用界面中可重复使用的一部分。Fragment定义和管理自己的布局&#xff0c;具有自己的生命周期&#xff0c;并且可以处理自己的输入事件。…...

Python 网页爬虫原理及代理 IP 使用

目录 前言 一、Python 网页爬虫原理 二、Python 网页爬虫案例 步骤1&#xff1a;分析网页 步骤2&#xff1a;提取数据 步骤3&#xff1a;存储数据 三、使用代理 IP 四、总结 前言 随着互联网的发展&#xff0c;网络上的信息量变得越来越庞大。对于数据分析人员和研究人…...

失效的访问控制及漏洞复现

失效的访问控制(越权) 1. 失效的访问控制(越权) 1.1 OWASP TOP10 1.1.1 A5:2017-Broken Access Control 未对通过身份验证的用户实施恰当的访问控制。攻击者可以利用这些缺陷访问未经授权的功能或数据&#xff0c;例如&#xff1a;访问其他用户的帐户、查看敏感文件、修改其…...

MLOps:掌握机器学习部署:Docker、Kubernetes、Helm 现代 Web 框架

介绍&#xff1a; 在机器学习的动态世界中&#xff0c;从开发模型到将其投入生产的过程通常被认为是复杂且多方面的。 然而&#xff0c;随着 Docker、Kubernetes 等工具以及 FastAPI、Streamlit 和 Gradio 等用户友好的 Web 框架的出现&#xff0c;这一过程变得比以往更加简化…...

Python标识符命名规范

简单地理解&#xff0c;标识符就是一个名字&#xff0c;就好像我们每个人都有属于自己的名字&#xff0c;它的主要作用就是作为变量、函数、类、模块以及其他对象的名称。 Python 中标识符的命名不是随意的&#xff0c;而是要遵守一定的命令规则&#xff0c;比如说&#xff1a;…...

对 fastq 和 bam 进行 downsample

对 fastq 和 bam 进行 downsample 一、Fastq1、seqtk二、Bam1、samtools2、Picard DownsampleSam3、比较 并行采样模板 一、Fastq 1、seqtk Seqtk 是一种快速轻量级的工具&#xff0c;用于处理 FASTA 或 FASTQ 格式的序列。 它可以无缝解析 FASTA 和 FASTQ 文件&#xff0c;这…...

网络爬虫:如何有效的检测分布式爬虫

分布式爬虫是一种高效的爬虫方式&#xff0c;它可以将爬虫任务分配给多个节点同时执行&#xff0c;从而加快爬虫的速度。然而&#xff0c;分布式爬虫也容易被目标网站识别为恶意行为&#xff0c;从而导致IP被封禁。那么&#xff0c;如何有效地检测分布式爬虫呢&#xff1f;本文…...

elementUI可拖拉宽度抽屉

1&#xff0c;需求&#xff1a; 在elementUI的抽屉基础上&#xff0c;添加可拖动侧边栏宽度的功能&#xff0c;实现效果如下&#xff1a; 2&#xff0c;在原组件上添加自定义命令 <el-drawer v-drawerDrag"left" :visible.sync"drawerVisible" direc…...

OpenPCDet系列 | 8.4 nuScenes数据集数据调用和数据分析

文章目录 1. 对数据集遍历1.1 统计mini版本的nuScenes各模态数据和关键帧的数量1.2 单独遍历lidar模态数据1.3 遍历scene统计数据1.4 遍历sample统计数据1.5 遍历sample_data统计数据1.6 数据集的底层结构2. 对数据集可视化2.1 render_sample和render_sample_data2.2 nusc.rend…...

WeiTitlePopupWindow

目录 1 WeiTitlePopupWindow 1.1 // 设置可点击 1.2 // 设置弹窗外可点击 1.3 // 设置弹窗宽度和高度 1.4 // 设置弹窗布局界面 WeiTitlePopupWindow // 设置可点击setTouchable(true);...

qemu/kvm学习笔记

qemu/kvm架构 cpu虚拟化的示例 Reference: kvmtest.c [LWN.net] 主要步骤&#xff1a; QEMU通过/dev/kvm设备文件发起KVM_CREATE_VM ioctl&#xff0c;请求KVM创建一个虚拟机。KVM创建虚拟机相应的结构体&#xff0c;并为QEMU返回一个虚拟机文件描述符QEMU通过虚拟机文件描述…...

android 车载widget小部件部分详细源码实战开发-千里马车载车机framework开发实战课程

官网参考链接&#xff1a;https://developer.android.google.cn/develop/ui/views/appwidgets/overview 1、什么是小部件 App widgets are miniature application views that can be embedded in other applications (such as the home screen) and receive periodic updates…...

如何使用CSS画一个三角形

原理&#xff1a;其实就是规定元素的四个边框颜色及边框宽度&#xff0c;将元素宽高设置为0。如果要哪个方向的三角形&#xff0c;将对应其他三个方向的边框宽和颜色设置为0和透明transparent即可 1.元素设置边框&#xff0c;宽高&#xff0c;背景色 <style>.border {w…...

第15章_锁: (表级锁、页级锁、行锁、悲观锁、乐观锁、全局锁、死锁)

3.2 从数据操作的粒度划分&#xff1a;表级锁、页级锁、行锁 为了提高数据库并发度&#xff0c;每次锁定的数据范围越小越好&#xff0c;理论上每次只锁定当前操作的数据的方案会得到最大的并发度&#xff0c;但管理锁是很耗资源&#xff08;涉及获取、检查、释放锁等动作)。因…...

python音频转文字调用baidu

python音频转文字调用的是百度智能云的接口&#xff0c;因业务需求会涉及比较多数字&#xff0c;所以这里做了数字的处理&#xff0c;可根据自己的需求修改。 from flask import Flask, request, jsonify import requestsfrom flask_limiter import Limiterapp Flask(__name_…...

靶场溯源第二题

关卡描述&#xff1a;1. 网站后台登陆地址是多少&#xff1f;&#xff08;相对路径&#xff09; 首先这种确定的网站访问的都是http或者https协议&#xff0c;搜索http看看。关于http的就这两个信息&#xff0c;然后172.16.60.199出现最多&#xff0c;先过滤这个ip看看 这个很…...

mysql 的增删改查以及模糊查询、字符集语句的使用

一、mysql启动与登陆(windows下的mysql操作) 1.启动mysql服务 net start mysql81 2.登陆mysql mysql -uroot -p 3.查看所有数据库 show databases; 二、模糊查询&#xff08;like&#xff09; 1. _代表查询单个 2.%代表查询多个 3.查找所有含有schema的数据库&#xff1b;…...

Python Django框架中文教程:学习简单、灵活、高效的Web应用程序框架

概述: Python Django是一种流行的Web应用程序框架&#xff0c;被广泛应用于开发高效、可扩展的网站和Web应用程序。Django以其简单、灵活和高效而受到开发者们的青睐。它提供了强大的工具和功能&#xff0c;使开发过程更加容易和高效。 Django的主要目标是帮助开发者快速构建…...

Docker认识即安装

Docker及相关概念 Docker和虚拟机方式的区别&#xff1a;虚拟机技术是虚拟出一套硬件后&#xff0c;在其上运行一个完整的操作系统&#xff0c;在该系统上在运行所需应用进程&#xff1b;而容器内的应用进程是直接运行于宿主的内核&#xff0c;容器内没有自己的内核&#xff0…...

CTF show Web 红包题第六弹

提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框&#xff0c;很难让人不联想到SQL注入&#xff0c;但提示都说了不是SQL注入&#xff0c;所以就不往这方面想了 ​ 先查看一下网页源码&#xff0c;发现一段JavaScript代码&#xff0c;有一个关键类ctfs…...

突破不可导策略的训练难题:零阶优化与强化学习的深度嵌合

强化学习&#xff08;Reinforcement Learning, RL&#xff09;是工业领域智能控制的重要方法。它的基本原理是将最优控制问题建模为马尔可夫决策过程&#xff0c;然后使用强化学习的Actor-Critic机制&#xff08;中文译作“知行互动”机制&#xff09;&#xff0c;逐步迭代求解…...

相机Camera日志分析之三十一:高通Camx HAL十种流程基础分析关键字汇总(后续持续更新中)

【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:有对最普通的场景进行各个日志注释讲解,但相机场景太多,日志差异也巨大。后面将展示各种场景下的日志。 通过notepad++打开场景下的日志,通过下列分类关键字搜索,即可清晰的分析不同场景的相机运行流程差异…...

《基于Apache Flink的流处理》笔记

思维导图 1-3 章 4-7章 8-11 章 参考资料 源码&#xff1a; https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...

实现弹窗随键盘上移居中

实现弹窗随键盘上移的核心思路 在Android中&#xff0c;可以通过监听键盘的显示和隐藏事件&#xff0c;动态调整弹窗的位置。关键点在于获取键盘高度&#xff0c;并计算剩余屏幕空间以重新定位弹窗。 // 在Activity或Fragment中设置键盘监听 val rootView findViewById<V…...

AspectJ 在 Android 中的完整使用指南

一、环境配置&#xff08;Gradle 7.0 适配&#xff09; 1. 项目级 build.gradle // 注意&#xff1a;沪江插件已停更&#xff0c;推荐官方兼容方案 buildscript {dependencies {classpath org.aspectj:aspectjtools:1.9.9.1 // AspectJ 工具} } 2. 模块级 build.gradle plu…...

有限自动机到正规文法转换器v1.0

1 项目简介 这是一个功能强大的有限自动机&#xff08;Finite Automaton, FA&#xff09;到正规文法&#xff08;Regular Grammar&#xff09;转换器&#xff0c;它配备了一个直观且完整的图形用户界面&#xff0c;使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...

Python Ovito统计金刚石结构数量

大家好,我是小马老师。 本文介绍python ovito方法统计金刚石结构的方法。 Ovito Identify diamond structure命令可以识别和统计金刚石结构,但是无法直接输出结构的变化情况。 本文使用python调用ovito包的方法,可以持续统计各步的金刚石结构,具体代码如下: from ovito…...

解析奥地利 XARION激光超声检测系统:无膜光学麦克风 + 无耦合剂的技术协同优势及多元应用

在工业制造领域&#xff0c;无损检测&#xff08;NDT)的精度与效率直接影响产品质量与生产安全。奥地利 XARION开发的激光超声精密检测系统&#xff0c;以非接触式光学麦克风技术为核心&#xff0c;打破传统检测瓶颈&#xff0c;为半导体、航空航天、汽车制造等行业提供了高灵敏…...

Spring Boot + MyBatis 集成支付宝支付流程

Spring Boot MyBatis 集成支付宝支付流程 核心流程 商户系统生成订单调用支付宝创建预支付订单用户跳转支付宝完成支付支付宝异步通知支付结果商户处理支付结果更新订单状态支付宝同步跳转回商户页面 代码实现示例&#xff08;电脑网站支付&#xff09; 1. 添加依赖 <!…...