WIFI管理类

class WifiConnector {
private ExecutorService executors;
Handler mHandler;
WifiManager wifiManager; WifiConnector(WifiManager wifiManager, Handler handler) {
this.wifiManager = wifiManager;
executors= Executors.newSingleThreadExecutor();
mHandler=handler;
} private void sendMsg(String info) {
if (mHandler != null) {
Message msg = new Message();
msg.obj = info;
mHandler.sendMessage(msg);
}
} //WIFICIPHER_WEP是WEP ,WIFICIPHER_WPA是WPA,WIFICIPHER_NOPASS没有密码
public enum WifiCipherType {
WIFICIPHER_WEP, WIFICIPHER_WPA, WIFICIPHER_NOPASS, WIFICIPHER_INVALID
} // 打开wifi
public boolean openWifi() {
return !wifiManager.isWifiEnabled() && wifiManager.setWifiEnabled(true);
}
// 关闭wifi
public void closeWifi() {
if (!wifiManager.isWifiEnabled()) {
wifiManager.setWifiEnabled(false); }
}
//断开当前连接
public boolean disconnectWifi() {
return wifiManager.disconnect();
} //扫描wifi信息
public void scanWifi(){
if(wifiManager.isWifiEnabled()){
//扫描热点 如果扫描不到热点 把targetSdkVersion改成22
wifiManager.startScan();
}
} //获取热点信息 ScanResult.SSID 获取热点名字 ScanResult.level 获取热点信号强度
public List<ScanResult> scanResultsWifi(){
if(wifiManager.isWifiEnabled()){
//扫描热点 如果扫描不到热点 把targetSdkVersion改成22
return wifiManager.getScanResults();
}
return null;
} // 连接指定wifi
public void connect(String ssid, String password, WifiCipherType type) {
executors.execute(new Thread(new ConnectRunnable(ssid, password, type)));
} // 查看以前是否也配置过这个网络
public WifiConfiguration isExsits(String SSID) {
List<WifiConfiguration> existingConfigs = wifiManager .getConfiguredNetworks();
for (WifiConfiguration existingConfig : existingConfigs) {
if (existingConfig.SSID.equals("\"" + SSID + "\"")) {
return existingConfig;
}
}
return null;
} //配置wifi信息
private WifiConfiguration createWifiInfo(String SSID, String Password,
WifiCipherType Type) {
WifiConfiguration config = new WifiConfiguration();
config.allowedAuthAlgorithms.clear();
config.allowedGroupCiphers.clear();
config.allowedKeyManagement.clear();
config.allowedPairwiseCiphers.clear();
config.allowedProtocols.clear();
config.SSID = "\"" + SSID + "\""; WifiConfiguration tempConfig =isExsits(SSID); // nopass
if (Type == WifiCipherType.WIFICIPHER_NOPASS) {
config.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.NONE);
}
// wep
if (Type == WifiCipherType.WIFICIPHER_WEP) {
if (!TextUtils.isEmpty(Password)) {
if (isHexWepKey(Password)) {
config.wepKeys[0] = Password;
} else {
config.wepKeys[0] = "\"" + Password + "\"";
}
}
config.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.OPEN);
config.allowedAuthAlgorithms.set(WifiConfiguration.AuthAlgorithm.SHARED);
config.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.NONE);
config.wepTxKeyIndex = 0;
}
// wpa
if (Type == WifiCipherType.WIFICIPHER_WPA) {
config.preSharedKey = "\"" + Password + "\"";
config.hiddenSSID = true;
config.allowedAuthAlgorithms
.set(WifiConfiguration.AuthAlgorithm.OPEN);
config.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.TKIP);
config.allowedKeyManagement.set(WifiConfiguration.KeyMgmt.WPA_PSK);
config.allowedPairwiseCiphers
.set(WifiConfiguration.PairwiseCipher.TKIP);
// 此处需要修改否则不能自动重联
// config.allowedProtocols.set(WifiConfiguration.Protocol.WPA);
config.allowedGroupCiphers.set(WifiConfiguration.GroupCipher.CCMP);
config.allowedPairwiseCiphers
.set(WifiConfiguration.PairwiseCipher.CCMP);
config.status = WifiConfiguration.Status.ENABLED;
}
return config;
} class ConnectRunnable implements Runnable {
private String ssid;
private String password;
private WifiCipherType type; private ConnectRunnable(String ssid, String password, WifiCipherType type) {
this.ssid = ssid;
this.password = password;
this.type = type;
} @Override
public void run() {
try {
// 开启wifi功能需要一段时间(我在手机上测试一般需要1-3秒左右),所以要等到wifi
// 状态变成WIFI_STATE_ENABLED的时候才能执行下面的语句
while (wifiManager.getWifiState() == WifiManager.WIFI_STATE_ENABLING) {
try {
Thread.sleep(100);
} catch (InterruptedException ignored) {
}
}
WifiConfiguration wifiConfig = createWifiInfo(ssid, password,type);
if (wifiConfig == null) {
return;
}
WifiConfiguration tempConfig = isExsits(ssid);
if (tempConfig != null) {
wifiManager.removeNetwork(tempConfig.networkId);
}
int netID = wifiManager.addNetwork(wifiConfig);
boolean enabled = wifiManager.enableNetwork(netID, true);
Thread.sleep(1000);
if(enabled){
sendMsg("0");
}else{
sendMsg("1");
}
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
}
} private static boolean isHexWepKey(String wepKey) {
final int len = wepKey.length();
// WEP-40, WEP-104, and some vendors using 256-bit WEP (WEP-232?)
return !(len != 10 && len != 26 && len != 58) && isHex(wepKey);
} private static boolean isHex(String key) {
for (int i = key.length() - 1; i >= 0; i--) {
final char c = key.charAt(i);
if (!(c >= '0' && c <= '9' || c >= 'A' && c <= 'F' || c >= 'a'
&& c <= 'f')) {
return false;
}
}
return true;
}
}

连接指定WIFI

public class MainActivity extends AppCompatActivity implements ICheckDialogListener{
private ListView listview;
private CheckDialog dialg;
private Button scranButton;
private WifiManager mainWifi;
private WifiReceiver receiverWifi;
private WifiConnector wifycon; // 连接WIFI
private ScanResult scanRet;
//扫描出的wifi列表
public List<ScanResult> wifiList;
//选中的wifi项
private int wifiPosition; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
scranButton=findViewById(R.id.scranButton);
listview=findViewById(R.id.listview);
dialg=new CheckDialog(this,R.style.AppTheme,this); //初始化wifi管理器 这里如果用this可能会造成内存泄漏
mainWifi = (WifiManager) getApplicationContext().getApplicationContext().getSystemService(Context.WIFI_SERVICE);
//监听wifi的广播,必须动态注册
receiverWifi = new WifiReceiver();
//初始化wifi连接类
wifycon=new WifiConnector(mainWifi,handler); scranButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//判断wifi是否打开,否则打开
wifycon.openWifi();
//扫描热点 如果扫描不到热点 把targetSdkVersion改成22
//mainWifi.startScan();
Toast.makeText(MainActivity.this,"扫描WIFI热点,请稍候", Toast.LENGTH_SHORT).show();
}
}); }
protected void onResume(){
super.onResume();
//注册广播
registerReceiver(receiverWifi, new IntentFilter(
WifiManager.SCAN_RESULTS_AVAILABLE_ACTION));
} class WifiReceiver extends BroadcastReceiver{
public void onReceive(Context context, Intent intent){
//扫描完毕接受到的广播
if (intent.getAction().equals(
WifiManager.SCAN_RESULTS_AVAILABLE_ACTION)){
wifycon.scanWifi();
wifiList=wifycon.scanResultsWifi();
ArrayAdapter<String> adapter = new ArrayAdapter<>(MainActivity.this,
R.layout.wify_item,
getString(wifiList));
listview.setAdapter(adapter);
listview.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
dialg.show();
wifiPosition=position;
}
});
}
}
} @SuppressLint("HandlerLeak")
Handler handler=new Handler() {
@Override
public void handleMessage(Message msg) {
if("0".equals(msg.obj.toString())){
Toast.makeText(MainActivity.this,msg.obj.toString(),Toast.LENGTH_SHORT).show();
}else if("1".equals(msg.obj.toString())){
Toast.makeText(MainActivity.this,"密码输入错误!",Toast.LENGTH_SHORT).show();
}
}
}; @Override
public void sendStr(String msg) {
scanRet = wifiList.get(wifiPosition);
wifycon.connect(scanRet.SSID,msg, WifiConnector.WifiCipherType.WIFICIPHER_WPA);
} public String[] getString(List<ScanResult> wifiList){
ArrayList<String> listStr = new ArrayList<>(); for (int i = 0; i < wifiList.size(); i++){
listStr.add(wifiList.get(i).SSID);
}
return listStr.toArray(new String[0]);
}
}

回调接口

public interface ICheckDialogListener {
public void sendStr(String msg) ;
}

弹框验证

public class CheckDialog extends Dialog implements View.OnClickListener {
private EditText tvContent;
private Button butCancel;
private Button but_confirm;
private Activity context;
private ICheckDialogListener dialogListener;
public CheckDialog(Activity context, int theme, ICheckDialogListener dialListener) {
super(context, theme);
this.context = context;
dialogListener=dialListener;
} @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.check_dialog);
tvContent=findViewById(R.id.tv_content);
butCancel=findViewById(R.id.but_cancel);
butCancel.setOnClickListener(this);
but_confirm =findViewById(R.id.but_confirm);
but_confirm.setOnClickListener(this); } @Override
public void onClick(View v) {
if (v.getId() == R.id.but_confirm) {
String key = (tvContent.getText() + "").trim();
if ("".equals(key) | "null".equals(key)) {
Toast.makeText(context, "输入不能为空!", Toast.LENGTH_SHORT).show();
} else if (dialogListener==null) {
context.finish();
System.exit(0);
} else if(dialogListener!=null){
dialogListener.sendStr(key);
} else{
Toast.makeText(context, "密码输入错误!!", Toast.LENGTH_SHORT).show();
}
this.dismiss();
}else if(v.getId() == R.id.but_cancel){
this.dismiss();
}
}
}

Android WIFI的基本操作的更多相关文章

  1. Android Wi-Fi基本操作

    从用户角度看,Android Wi-Fi模块自下向上可以看为5层:硬件驱动程序,wpa_suppplicant,JNI,WiFi API,WifiSettings应用程序. 1.wpa_supplic ...

  2. Android WIFI 分析(一)

    本文基于<深入理解Android WiFi NFC和GPS 卷>和 Android N 代码结合分析   WifiService 是 Frameworks中负责wifi功能的核心服务,它主 ...

  3. android wifi P2P CONNECT, INVITE和JOIN流程选择

    android wifi P2P CONNECT, INVITE和JOIN流程选择

  4. android wifi ANR问题分析总结

    android wifi ANR问题分析总结 1 看看main进程阻塞在那里? 2 调用关系的函数阻塞在那里? 3 最终阻塞函数的阻塞前的log以及状态

  5. android wifi驱动移植详细过程

    转自:http://bbs.imp3.net/thread-10558924-1-1.html 对于刚入手android没多久的人来说,android wifi 驱动的移植确实还是有难度的,不过参考了 ...

  6. Android WIFI 启动流程(TIP^^)

    前几天因为解决一堆Bug,没时间写.我不会每天都写,就是为了存档一些资料. 内容来源:工作中接触到的+高手博客+文档(Books)=自己理解 仅限参考^^ 此博客是上一个<<Android ...

  7. android——wifi系统架构

    1. 系统架构 Android WiFi系统引入了wpa_supplicant,它的整个WiFi系统以wpa_supplicant为核心来定义上层用户接口和下层驱动接口.整个WiFi系统架构如下图所示 ...

  8. Android WiFi管理(WIFI_SERVICE)

    Android WiFi管理(WIFI_SERVICE) 分类: Android2011-11-24 10:52 2000人阅读 评论(1) 收藏 举报 androidservicebuttonlay ...

  9. Android Wi-Fi Display(Miracast)介绍

    地址:http://blog.csdn.net/innost/article/details/8474683 Android Wi-Fi Display(Miracast)介绍 2012年11月中旬, ...

随机推荐

  1. ASP.NET Core中自定义路由约束

    路由约束 ASP.NET Core中,通过定义路由模板,可以在Url上传递变量,同时可以针对变量提供默认值.可选和约束. 约束的使用方法是在属性路由上添加指定的约束名,用法如下: // 单个使用 [R ...

  2. ubuntu16.04 编译出错:fatal error: SDL/SDL.h: No such file or directory

    在ubuntu 16.04编译神经网络代码时候,遇到了这样一种错误? fatal error: SDL/SDL.h: No such file or directory 原因是SDL库没有安装,根据你 ...

  3. [EXP]Apache Superset < 0.23 - Remote Code Execution

    # Exploit Title: Apache Superset < 0.23 - Remote Code Execution # Date: 2018-05-17 # Exploit Auth ...

  4. PHP扩展开发教程(总结)

    PHP是一种解释型的语言,对于用户而言,我们精心的控制内存意味着easier prototyping和更少的崩溃!当我们深入到内核之后,所有的安全防线都已经被越过,最终还是要依赖于真正有责任心的软件工 ...

  5. XOR+base64加密

    1.xor运算 1^0=1 0^0=0 1^1=0 23^32=55 55^32=23 23对32进行异或两次运算结果为23 2.XOR加密 设key=[]byte{1,2,3,4,5,6},src= ...

  6. PostgreSQL事务实现

    事务简介 事务管理器:有限状态机 日志管理器 CLOG:事务的执行结果 XLOG:undo/redo日志 锁管理器:实现并发控制,读阶段采用MVCC,写阶段采用锁控制实现不同的隔离级别 Postgre ...

  7. JS判断是否是数组的四种做法

    一.前言 如何判断一个对象或一个值是否是一个数组,在面试或工作中我们常常会遇到这个问题,既然出现频率高,想着还是做个整理,那么本文主要基于几种判断方式,以及方式判断的原理,是否存在问题展开讨论. 二. ...

  8. Linux进程间通信(System V) --- 信号量

    信号量 IPC 原理 信号量通信机制主要用来实现进程间同步,避免并发访问共享资源.信号量可以标识系统可用资源的个数.最简单的信号量为二元信号量 下图为 Linux 信号量通信机制的概念图.在实际应用中 ...

  9. C语言之链表的使用

    C语言链表初学者都说很难,今天就来为大家讲讲链表 讲链表之前不得不介绍一下结构体,在链表学习之前大家都应该已经学了结构体,都知道结构体里面能有许多变量,每个变量可以当做这个结构体的属性,例如: str ...

  10. 聚簇索引(聚集索引) 不可作用于GUID类型字段

    聚簇索引(又名聚集索引) 不可作用于GUID类型字段,即:数据库中不要把GUID类型作为主键或设置为聚集索引. 聚集索引:索引的物理存储顺序与数据表中行数据物理存储顺序一致(索引存储物理有序). 非聚 ...