读取Android设备的MAC地址
读取Android设备的MAC地址
AndroidUtil.java
package com.csdn.android.util;
import com.csdn.android.framework.util.StringUtil;
import android.content.Context;
import android.net.wifi.WifiInfo;
import android.net.wifi.WifiManager;
import android.telephony.TelephonyManager;
public class AndroidUtil
{
//是否允许MAC使用MAC地址
private static boolean ALLOW_MAC=true;
//唯一标识的长度
private static int IDENTIFY_LEN=14;
//MAC地址的标识
private static String KEY_MAC="android_mac";
//初始化IMEI
private static boolean mIntiIMEI = false;
//初始化MAC
private static boolean mInitMAC=false;
//IMEI缓存
private static String mIMEI;
//MAC地址缓存
private static String mMAC;
//是否读取缓存
private static boolean mReaderCache=false;
//是否读取的MAC地址
public static boolean isReaderMac()
{
//没有完成
if(!isInitCompeleted())
{
return false;
}
//不允许MAC地址
if(!ALLOW_MAC)
{
return false;
}
//取IMEI地址
if(!StringUtil.isNull(getIMEI()))
{
return false;
}
//取MAC地址
return true;
}
//判断是否读取缓存
public static boolean isReaderMACCache()
{
return mReaderCache;
}
//获取IMEI地址
private static String getIMEI() {
if (mIntiIMEI) {
return mIMEI;
}
TelephonyManager telephonyManager = (TelephonyManager) FrameHelper
.getAppContext().getSystemService(Context.TELEPHONY_SERVICE);
try {
mIMEI = telephonyManager.getDeviceId();
} catch (Exception e) {
}
mIntiIMEI = true;
return mIMEI;
}
//是否初始化完成
public static boolean isInitCompeleted()
{
if(!StringUtil.isNull(getIMEI()) || mInitMAC)
{
return true;
}
return false;
}
/**
* 获取设备唯一标识,IMEI 或者 MAC
* @return
*/
public static String getIdentifyId()
{
//没有完成
if(!isInitCompeleted())
{
return null;
}
//不允许MAC地址
if(!ALLOW_MAC)
{
return getIMEI();
}
//取IMEI地址
if(!StringUtil.isNull(getIMEI()))
{
return getIMEI();
}
//取MAC地址
return getMAC();
}
//获取MAC地址
public static String getMAC()
{
if (mInitMAC)
{
return mMAC;
}
return null;
}
//获取真实MAC地址
public static String getMACSource()
{
if (mInitMAC && !StringUtil.isNull(mMAC))
{
if(mMAC.length()>12)
{
return mMAC.substring(0, 12);
}
return mMAC;
}
return "";
}
public static boolean initMACInMainThread()
{
return initMAC(1,true);
}
public static boolean initMACdoInBackground()
{
//尝试100次
return initMAC(100,false);
}
//后台获取MAC地址
public static String getMacFromDeviceInBackground()
{
return getMacFromDevice(100);
}
private static boolean initMAC(int internal,boolean readerCache)
{
String mac = null;
//是否读取缓存
if(readerCache)
{
//通过缓存获取
mac = FrameHelper.readSharedData(FrameHelper.getAppContext(), KEY_MAC);
if(!StringUtil.isNull(mac))
{
mInitMAC = true;
mMAC = mac;
mReaderCache =true;
return true;
}
}
mac = getMacFromDevice(internal);
if(!StringUtil.isNull(mac))
{
saveMacInfo(mac);
mReaderCache = false;
return true;
}
return false;
}
//保存Mac地址
public static void saveMacInfo(String mac)
{
mInitMAC = true;
mMAC = mac;
FrameHelper.saveSharedData(FrameHelper.getAppContext(), KEY_MAC,mMAC);
}
//尝试读取MAC地址
private static String getMacFromDevice(int internal)
{
String mac=null;
WifiManager wifiManager = (WifiManager) FrameHelper.getAppContext().getSystemService(Context.WIFI_SERVICE);
//尝试获取mac
mac = tryGetMAC(wifiManager);
if(!StringUtil.isNull(mac))
{
return mac;
}
//获取失败,尝试打开wifi获取
boolean isOkWifi = tryOpenMAC(wifiManager);
for(int index=0;index<internal;index++)
{
//如果第一次没有成功,第二次做100毫秒的延迟。
if(index!=0)
{
try
{
Thread.sleep(100);
}
catch (InterruptedException e)
{
e.printStackTrace();
}
}
mac = tryGetMAC(wifiManager);
if(!StringUtil.isNull(mac))
{
break;
}
}
//尝试关闭wifi
if(isOkWifi)
{
tryCloseMAC(wifiManager);
}
return mac;
}
//尝试打开MAC
private static boolean tryOpenMAC(WifiManager manager)
{
boolean softOpenWifi = false;
int state = manager.getWifiState();
if (state != WifiManager.WIFI_STATE_ENABLED && state != WifiManager.WIFI_STATE_ENABLING)
{
manager.setWifiEnabled(true);
softOpenWifi = true;
}
return softOpenWifi;
}
//尝试关闭MAC
private static void tryCloseMAC(WifiManager manager)
{
manager.setWifiEnabled(false);
}
//尝试获取MAC地址
private static String tryGetMAC(WifiManager manager)
{
WifiInfo wifiInfo = manager.getConnectionInfo();
if (wifiInfo == null || StringUtil.isNull(wifiInfo.getMacAddress()))
{
return null;
}
String mac = wifiInfo.getMacAddress().replaceAll(":", "").trim().toUpperCase();
mac = formatIdentify(mac);
return mac;
}
//格式化唯一标识
private static String formatIdentify(String identify)
{
//判空
if(StringUtil.isNull(identify))
{
return identify;
}
//去除空格
identify = identify.trim();
//求长度
int len = identify.length();
//正好
if(len== IDENTIFY_LEN)
{
return identify;
}
//过长,截取
if(len>IDENTIFY_LEN)
{
return identify.substring(0, IDENTIFY_LEN);
}
//过短,补0
for(;len<IDENTIFY_LEN;len++)
{
identify += "0";
}
//大于默认
return identify;
}
}
读取Android设备的MAC地址的更多相关文章
- (转)【Android】获取Mac地址【2】
[Android]获取Mac地址[2] 之前写了[Android]获取Mac地址[1]有些不够详细,现在贴上一些其他代码,仅供参考. (1) 调用android 的API: NetworkInterf ...
- 获取设备的mac地址可靠的方法
参考自:http://www.open-open.com/lib/view/open1433406847322.html /** * 获取设备的mac地址 * * @param ac * @param ...
- iOS7以下设备获取mac地址
注意,是iOS7以下的设备,直接上源码,获取mac地址都是为了唯一标识一个设备的,但iOS7设备的mac地址为 020000000000 MacAddress.h #include <sys/s ...
- Android 获取WIFI MAC地址的方法
1. 经常用法,调用Android的API:WifiManager <uses-permission android:name="android.permission.ACCESS_W ...
- 正确获得android设备的IP地址
网上此类获得android设备IP地址相关的文章有不少,有一篇是比较通用的,但有一个问题:有些设备默认的是IPv6的地址,那段代码获得的就是IPv6的地址.但这显然不是我们想要的,我们需要的是IPv4 ...
- Android 获取手机Mac地址,手机名称
/** * 获取手机mac地址<br/> * 错误返回12个0 */ public static String getMacAddress(Context context) { // 获取 ...
- 获取设备的mac地址和IP地址(android6.0以上专用)
/** * 获取设备HardwareAddress地址 * @return */public static String getMachineHardwareAddress(){ Enumeratio ...
- Qt 中使用Java代码获取安卓设备的MAC地址(安卓9.0)
public String GetDeviceMAC() { String strMacAddr = null; try { // 获得IpD地址 InetAddress ip = getLocalI ...
- 获取Android设备WIFI的MAC地址 “MAC地址”
需要指出的是:wifi状态和wifi AP状态是互斥的状态:也就是一旦发现WIFI AP打开,WIFI是不能被打开的. 获取Android设备的WIFI MAC地址,首先需要将设备中的WIFI个人热点 ...
随机推荐
- 浅谈Unity中的GC以及优化
介绍: 在游戏运行的时候,数据主要存储在内存中,当游戏的数据不在需要的时候,存储当前数据的内存就可以被回收再次使用.内存垃圾是指当前废弃数据所占用的内存,垃圾回收(GC)是指将废弃的内存重新回收再次使 ...
- OAuth认证协议原理分析及同步消息到Twitter和Facebook使用方法
OAuth有什么用?为什么要使用OAuth? twitter或豆瓣用户一定会发现,有时候,在别的网站,点登录后转到 twitter登录,之后转回原网站,你会发现你已经登录此网站了,这种网站就是这个效果 ...
- 【BZOJ】1024: [SCOI2009]生日快乐(dfs)
http://www.lydsy.com/JudgeOnline/problem.php?id=1024 果然现在弱到连搜索都不会了么..... 一直想二分...但是无论如何也推不出怎么划分... Q ...
- 小结:bfs
概要: 我们在初始状态要到达终止状态可以沿着同深度的向下搜索,这样范围覆盖更广,在解的深度较小的时候十分适用. 技巧及注意: 所有状态在转移后如果要打标记一定要在进队列前打!不要在出队列才打!否则就是 ...
- erlang的汉字字符串和二进制的相互转换,并还原成汉字打印
19> Hanzi = <<"汉字"/utf8>>. <<230,177,137,229,173,151>> 20> i ...
- Linux性能分析top iostat vmstat free
最近看到一大牛的分析报告,才知道笔者认识这4个命令是多么肤浅,其实要读懂内存的信息,是要一些功力的.1.top VIRT 虚拟内存总量,VIRT=SWAP+RESSWAP ...
- 【NLP】course
http://52opencourse.com/235/%E6%96%AF%E5%9D%A6%E7%A6%8F%E5%A4%A7%E5%AD%A6%E8%87%AA%E7%84%B6%E8%AF%AD ...
- hdu 4496(并查集)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4496. 思路:简单并查集应用,从后往前算就可以了. #include<iostream> ...
- 编程之美 set 9 字符串移位包含问题
题目 给定字符串 s1 和 s2, 要求判定 s2能否能够被通过 s1 做循环移位得到的字符包含. s1 = AABCD, s2 = CDAA 返回 true. 给定 s1 = ABCD 和 s2 = ...
- OpenGL编程指南第九章:纹理映射
转自://http://blog.csdn.net/longhuihu/article/details/8477614 纹理(texture)是一块矩形数据序列,存储的数据为颜色.亮度.alpha值. ...