Andriod wifi 基本操作
-
从用户角度看,Android Wi-Fi模块自下向上可以看为5层:硬件驱动程序,wpa_suppplicant,JNI,WiFi API,WifiSettings应用程序。
1.wpa_supplicant是一个开源库,是android实现Wi-Fi功能的基础,它从上层接到命令后,通过Socket与硬件驱动进行通讯,操作硬件完成需要的操作。
2.JNI(Java Native Interface)实现了java代码与其他代码的交互,使得在java虚拟机中运行的java代码能够与其他语言编写的应用程序和库进行交互,在android中,JNI可以让java程序调用C程序。
3.Wi-Fi API使应用程序可以使用Wi-Fi的功能。
4.Wi-FI Settings应用程序是android中自带的一个应用程序,选择手机的Settings->WireLess & netWorks->Wi-Fi,可以让用户手动打开或关闭Wi-Fi功能。当用户打开Wi-Fi功能后,它会自动搜索周围的无线网络,并以列表的 形式显示,供用户选择。默认会连接用户上一次成功连接的无线网络。
在android.net.wifi包中提供了一些类管理设备的Wi-Fi功能。主要包括ScanResult,wifiConfiguration,WifiInfo,WifiManager.
1.ScanResult
ScanResult主要是通过Wi-Fi硬件的扫描来获取一些周边的Wi-Fi热点的信息。该类包括以下五个域:
返回类型 域名 解释 public String BSSID 接入点地址 public String SSID 网络的名称 public String capabilities 网络性能,包括介入点支持的认证,密钥管理,加密机制等 public int frequency 以MHz为单位的接入频率 public int level 以dBm为单位的信号强度 该类还提供了一个方法toString(),可将结果转换为简洁,易读的字符串形式。
2.wifiConfiguration类
通过该类可获取一个Wi-Fi网络的网络配置,包括安全配置等。该类包括六个子类,如下:
子类 解释 WifiConfiguration.AuthAlgorthm 获取IEEE802.11的加密方法 WifiConfiguration.GroupCipher 获取组密钥 WifiConfiguration.KeyMgmt 获取密码管理机制 WifiConfiguration.PairwiseCipher 获取WPA方式的成对密钥 WifiConfiguration.Protocol 获取机密协议 WifiConfiguration.Status 获取当前网络状态 每个子类都以常量形式给出相关的配置信息,有些还包括含域和方法。
3.WifiInfo类
通过该类可以获取已经建立或处于活动状态的Wi-Fi网络的状态信息。该类提供的方法较多,部分常用的如下:
方法 解释 getBSSIS() 获取当前接入点的BSSID getIpAddress() 获取IP地址 getLinkSpeed() 获取当前连接的速度 getMacAddress() 获取MAC地址 getRssi() 获得802.11n网络的信号强度指示 getSSID() 获得网络SSID getSupplicanState() 返回客户端状态的信息 4.wifiManager类
该类用于管理Wi-Fi连接,其定义了26个常量和23个方法。下面列出常用方法:
方法 解释 addNetwork(WifiConfiguration config) 向设置好的网络里添加新网络 calculateSignalLevel(int rssi,int numLevels) 计算信号的等级 compareSignalLevel(int rssiA,int rssiB) 对比两个信号的强度 createWifiLock(int lockType,String tag) 创建一个Wi-Fi锁,锁定当前的Wi-Fi连接 disableNetWork(int netId) 让一个网络连接失败 disconnect() 与当前接入点断连接 enableNetwork(int netId,Boolean disableOthers) 与之前设置好的网络建立连接 getConfiguredNetworks() 客户端获取网络连接状态 getConnectionInfo() 获取当前连接信息 getDhcpInfo() 获取DHCP信息 getScanResult() 获取扫描测试结果 getWifiState() 获取一个Wi-Fi接入点是否有效 isWifiEnabled() 判断一个Wi-Fi连接是否有效 pingSupplicant() 看看客户后台程序是否响应请求 ressociate() 重连到接入点,即使已经连接上了 reconnect() 如果现在没有连接的话,则重连接 removeNetwork(int netId) 移出某一个特定网络 saveConfiguration() 保留一个配置信息 setWifiEnabled(boolean enabled) 让一个连接有效或失效 startScan() 开始扫描 updateNetwork(WifiConfiguration config) 更新一个网络连接信息 需要指出的是,Wi-Fi网卡状态是由一系列的整型常量来表示的。
WIFI_STATE_DISABLED:Wi-Fi网卡不可用,用整型常量1表示。
WIFI_STATE_DISABLING:Wi-Fi网卡正在关闭,用整型常量0表示。
WIFI_STATE_ENABLED:Wi-Fi网卡可用,用整型常量3表示。
WIFI_STATE_ENABLING:Wi-Fi网卡正在打开,启动需要一段时间,用整型常量2表示。
WIFI_STATE_UNKNOWN:未知网卡状态,用整型常量4表示。
此外wifiManager还提供了一个子类wifiManagerLock.wifiManagerLock的作用是这样的:在普通的状态下,如 果Wi-Fi的状态处于闲置,那么网络将会暂时中断;但是如果把当前的网络状态锁上,那么Wi-Fi连通将会保持在一定的状态,在结束锁定之后,才会恢复 常态。
下面简单介绍一些方法的调用方式
private WifiInfo mWifiInfo;
private WifiManager mWifiManager;
1.获取WifiManager系统服务
mWifiManager=(WifiManager)context.getSystemService(Context.WIFI_SERVICE);
2.重新获取当前Wi-Fi的连接信息
public void againGetWifiInfo(){
mWifiInfo=mWifiManager.getConnectionInfo();
}
3.判断用户是否开启wi-fi网卡
public boolean isNetCardFriendly(){
return mWifiManager.isWifiEnabled();
}
4.判断当前是否连接Wi-Fi
private State state;
//创建连接管理器
private ConnectivityManager connManager;
public boolean isConnectioning(){
state=connManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI).getState();
if(State.CONNECTING==state){
return true;
}else{
return false;
}
}
5.得到当前网络的连接状态
public State getCurrentState(){
state=connManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI).getState();
return state;
}
6.设置配置好的网络(有密码的网络并配置好密码),指定的
//网络连接列表
private List wifiConfigList=new ArrayList();
//Wi-Fi配置列表
private List wifiConfigedSpecifiedList=new ArrayList();
public void setWifiConfigedSpecifiedList(String ssid){
wifiConfigedSpecifiedList.clear();
if(wifiConfigList!=null){
for(WifiConfiguration item : wifiConfigList){
//如果是指定的网络,就加入列表
if(item.SSID.equalsIgnoreCase("\""+ssid+"\"")&& item.preSharedKey!=null){
//添加到列表中
wifiConfigedSpecifiedList.add(item);
}
}
}
}
7.返回Wi-Fi设置列表
public List getWifiConfigedSpecifiedList(){
return wifiConfigedSpecifiedList;
}
8.打开Wi-Fi网卡
public void openNetCard(){
if(!mWifiManager.isWifiEnabled()){
mWifiManager.setWifiEnabled(true);
}
}
9.关闭Wi-Fi网卡
public void closeNetCard(){
if(mWifiManager.isWifiEnabled()){
mWifiManager.setWifiEnabled(false);
}
}
10.检查当前Wi-Fi网卡状态
public void checkNetCardState(){
if(mWifiManager.getWifiState()==0){
Log.i("","网卡正在关闭");
}else if(mWifiManager.getWifiState()==1){
Log.i("","网卡已经关闭");
}else if(mWifiManager.getWifiState()==2){
Log.i("","网卡正在打开");
}else if(mWifiManager.getWifiState()==3){
Log.i("","网卡已经打开");
}else{
Log.i("","没有获取到状态");
}
}
11.扫描周边网络
//保存扫描结果列表
public List listResult=new ArrayList();
public void scan(){
//开始扫描
mWifiManager.startScan();
//获取扫描结果
listResult=mWifiManager.getScanResults();
//扫描配置列表
wifiConfigList=mWifiManager.getConfiguredNetworks();
if(listResult!=null){
//当前存在无线网络
}else{
//当前区域没有无线网络
}
}
12.返回扫描结果
public List getListResult(){
return listResult;
}
13.得到扫描结果
//存储扫描结果
private StringBuffer mStringBuffer=new StringBuffer();
private ScanResult mScanResult;
public String getScanResult(){
//每次点击扫描之前清空上一次扫描结果
if(mStringBuffer!=null){
mStringBuffer=new StringBuffer();
}
//开始扫描调用11的方法
scan();
listResult=mWifiManager.getScanResults();
if(listResult!=null){
for(int i=0;i
mScanResult=listResult.get(i);
//将需要的属性连接到字符串里面
mStringBuffer.append("NO.").append(i+1).append(" :").append(mScanResult.SSID).append("->").append(mScanResult.BSSID).append("->").append(mScanResult.capabilities).append("->").append(mScanResult.frequency).append("->").append(mScanResult.level).append("->").append(mScanResult.describeContents()).append("\n\n");
}
}
return mStringBuffer.toString();
}
14.断开当前连接的网络
public void disconnectWifi(){
//获取网络ID
int newId=getNetworkId();
//设置网络不可用
mWifiManager.disableNetWork(netId);
//断开网络
mWifiManager.disconnect();
//设置Wi-Fi信息为NULL
mWifiInfo=null;
}
15.检查当前网络状态
public Boolean checkNetWorkState(){
if(mWifiInfo!=null){
return true;
}else{
return false;
}
}
16.得到连接的ID
public int getNetworkId(){
return (mWifiInfo==null)?0:mWifiInfo.getNetworkId();
}
17.得到IP地址
public void getIPAddress(){
return (mWifiInfo==null)?0:mWifiInfo.getIpAddress();
}
18.锁定WifiLock
WinfiLock mWifiLock;
public void acquireWifilock(){
mWifiLock.acquire();
}
19.解锁WifiLock
public void releaseWifiLock(){
if(mWifiLock.isHeld()){
mWifiLock.acquire();
}
}
20.创建一个WifiLock
public void creatWifiLock(){
mWifiLock=mWifiManager.createWifiLock("test");
}
21.得到配置好的网络wpa_supplicant.conf中的内容,不管有没有配置密码
public List getConfiguration(){
return wifiConfigList;
}
22.指定配置好的网络连接
public Boolean connectConfiguration(int index)(){
//所引大于配置好的网络返回
if(index>=wifiConfigList.size()){
return false;
}
return mWifiManager.enableNetwork(wifiConfigedSpecifiedList.get(index).networkId,true);
}
23.得到MAX地址
public String getMacAddress(){
return (mWifiInfo=null)?"":mWifiInfo.getMacAddress();
}
24.得到接入点BSSID
public String getBSSID(){
return (mWifiInfo=null)?"NULL":mWifiInfo.getBSSID();
}
25.得到WifiInfo的所有信息包
public String getWifiInfo(){
return (mWifiInfo=null)?"NULL":mWifiInfo.toString();
}
26.添加一个网络并连接
public int addNetwork(WifiConfiguration g){
//添加网络
int wcgID=mWifiManager.addNetwork(g);
//设置添加的网络可用
mWifiManager.enableNetwork(wcgID,true);
return wcgID;
}
Andriod wifi 基本操作的更多相关文章
- Andriod WIFI驱动模块
一:什么是WIFI WIFI是一种无线连接技术,可用于手机.电脑.PDA等终端.WIFI技术产生的目的是改善基于IEEE802.11标准的无线网络产品之间的互通性,也就是说WIFI是基于802.11标 ...
- Android Wi-Fi基本操作
从用户角度看,Android Wi-Fi模块自下向上可以看为5层:硬件驱动程序,wpa_suppplicant,JNI,WiFi API,WifiSettings应用程序. 1.wpa_supplic ...
- 九、Android学习第八天——广播机制与WIFI网络操作(转)
(转自:http://wenku.baidu.com/view/af39b3164431b90d6c85c72f.html) 九.Android学习第八天——广播机制与WIFI网络操作 今天熟悉了An ...
- Android WIFI的基本操作
WIFI管理类 class WifiConnector { private ExecutorService executors; Handler mHandler; WifiManager wifiM ...
- Andriod小项目——在线音乐播放器
转载自: http://blog.csdn.net/sunkes/article/details/51189189 Andriod小项目——在线音乐播放器 Android在线音乐播放器 从大一开始就已 ...
- Fiddler基本原理与抓取Andriod与IOS的App数据包
Fiddler基本原理 Fiddler数据包的原理是Fiddler将自己设置为一个代理服务器,默认监听127.0.0.1:8888端口同时将浏览器的HTTP.HTTPS协议设置为使用代理服务器也就是使 ...
- Andriod环境搭建
安卓是一款现在在移动端十分流行的系统,本人出于好奇心,希望彻底了解安卓的开发技. 首先了解一下安卓的系统构架,安卓大致分为四层架构,五块区域: 1.Linux内核层 Andriod是基于Linux2. ...
- Windows 7/8 创建WIFI热点
问题描述:很多人(特别是中国的大学生)都拥有一台联网的笔记本电脑,而手机使用的却是电信运营商提供的限制数量和速度的GPRS. 很多人不敢想象:联网的笔记本电脑能够将其流量以WiFi的形式共享出来供其它 ...
- phonegap环境配置与基本操作
一.开发环境配置: 1.工具环境安装: 安装java sdk 1.6以上版本号,Android Development Tools.ant,系统变量 Path后面加入 新增名稱 JAVA_HOME 值 ...
随机推荐
- jQuery图片提示和文字提示
图片提示: 效果如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...
- hdu 4010 Query on The Trees LCT
支持:1.添加边 x,y2.删边 x,y3.对于路径x,y上的所有节点的值加上w4.询问路径x,y上的所有节点的最大权值 分析:裸的lct...rev忘了清零死循环了两小时... 1:就是link操作 ...
- 数理方程:Laplace变换 & 留数(更新中)
更新:25 APR 2016 Laplace变换 设函数\(f(t)\)在\(t>0\)时有定义,积分 \(F(s)=\int_0^{+\infty}f(t)e^{-st}dt \qquad ( ...
- .net C# 网页播放器 支持多种格式 媒体播放器 播放器 代码
.avi格式代码片断如下:<object id='video' width='400' height='200' border='0' classid='clsid:CFCDAA03-8BE4- ...
- CS加密算法
概述: 加密数据可以使用对称加密或非对称加密算法,使用对称加密比非对称密钥快得多,但对称密钥需要解决安全交换密钥的问题.在 .NET Framework中,可以使用System.Security.Cr ...
- POJ 2456
#include <iostream> #include <vector> #include <algorithm> using namespace std; un ...
- CSS之侧边栏
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 1 对WinMain的理解
就像C语言的main是它的程序路口一样,windows的程序入口是WinMain,WinMain的定义可以查看winbase.h文件. Hello Windows(c语言中的Hello world!) ...
- [老老实实学WCF] 第五篇 再探通信--ClientBase
老老实实学WCF 第五篇 再探通信--ClientBase 在上一篇中,我们抛开了服务引用和元数据交换,在客户端中手动添加了元数据代码,并利用通道工厂ChannelFactory<>类创 ...
- NodeJs多进程和socket.io通讯-DEMO
一.开启多进程 const os = require('os'); const cp = require('child_process'); const forkList = {}; const fo ...