原创内容,转载请注明原文网址:http://homeqin.cn/a/wenzhangboke/jishutiandi/Android/2019/0601/524.html
有良多场景和需要你须要用得手机建筑的唯独标识符。
在Android中,有如下几种要领获取这样的ID。
1. The IMEI: 仅仅只对Android手机有用:
1
2
TelephonyManager TelephonyMgr = (TelephonyManager)getSystemService(TELEPHONY_SERVICE);
String szImei = TelephonyMgr.getDeviceId();
接纳此种要领,须要在AndroidManifest.xml中进入一个允许:android.permission.READ_PHONE_STATE,而且用户该当容许安置此运用。作为手机来讲,IMEI是唯独的,它应该相似于 359881030314356(除非你有一个没有量产的手机(水货)它可能有无效的IMEI,如:0000000000000)。
2. Pseudo-Unique ID, 这个在任何Android手机中都有用
有少许分外的环境,少许如平板电脑的设置没有通话功效,大概你不愿进入READ_PHONE_STATE允许。而你仍旧想获取唯独序列号之类的东西。这时你可以通过取出ROM版本、制作商、CPU型号、以及其余硬件信息来实现这一点。这样计较出来的ID不是唯独的(由于要是两个手机运用了同样的硬件以及Rom 镜像)。但该当清晰的是,出现相似环境的可能性基本可以纰漏。要实现这一点,你可以运用Build类:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
String m_szDevIDShort = "35" + //we make this look like a valid IMEI
Build.BOARD.length()%10 +
Build.BRAND.length()%10 +
Build.CPU_ABI.length()%10 +
Build.DEVICE.length()%10 +
Build.DISPLAY.length()%10 +
Build.HOST.length()%10 +
Build.ID.length()%10 +
Build.MANUFACTURER.length()%10 +
Build.MODEL.length()%10 +
Build.PRODUCT.length()%10 +
Build.TAGS.length()%10 +
Build.TYPE.length()%10 +
Build.USER.length()%10 ; //13 digits
大无数的Build成员都是字符串形式的,我们只取他们的长度信息。我们取到13个数字,并在前方加上“35”。这样这个ID看起来就和15位IMEI同样了。
3. The Android ID
平时被觉得不行信,由于它偶然为null。开发文档中申明了:这个ID会转变要是举行了出厂设置。而且,要是某个Andorid手机被Root过的话,这个ID也能够被任意转变。
1
String m_szAndroidID = Secure.getString(getContentResolver(), Secure.ANDROID_ID);
Returns: 9774d56d682e549c . 无需任何允许。
4. The WLAN MAC Address string
是另一个唯独ID。不过你须要为你的工程进入android.permission.ACCESS_WIFI_STATE 权限,不然这个地点会为null。
1
2
WifiManager wm = (WifiManager)getSystemService(Context.WIFI_SERVICE);
String m_szWLANMAC = wm.getConnectionInfo().getMacAddress();
Returns: 00:11:22:33:44:55 (这不是一个确凿地点。而且这个地点能轻易地被捏造。).WLan无谓翻开,就可读取些值。
5. The BT MAC Address string
只在有蓝牙的建筑上运行。而且要进入android.permission.BLUETOOTH 权限.
1
2
3
BluetoothAdapter m_BluetoothAdapter = null; // Local Bluetooth adapter
m_BluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
String m_szBTMAC = m_BluetoothAdapter.getAddress();
Returns: 43:25:78:50:93:38 . 蓝牙没有须要翻开,也能读取。
Combined Device ID
综上所述,我们一公有五种方式获取建筑的唯独标识。它们中的少允许能会回笼null,大概由于硬件缺失、权限问题等获取腐朽。
但你总能获取至少一个能用。以是,最好的要领即是通过拼接,大概拼接后的计较出的MD5值来发生一个后果。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
String m_szLongID = m_szImei + m_szDevIDShort
+ m_szAndroidID+ m_szWLANMAC + m_szBTMAC;
// compute md5
MessageDigest m = null;
try {
m = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
m.update(m_szLongID.getBytes(),0,m_szLongID.length());
// get md5 bytes
byte p_md5Data[] = m.digest();
// create a hex string
String m_szUniqueID = new String();
for (int i=0;i<p_md5Data.length;i++) {
int b = (0xFF & p_md5Data[i]);
// if it is a single digit, make sure it have 0 in front (proper padding)
if (b <= 0xF)
m_szUniqueID+="0";
// add number to string
m_szUniqueID+=Integer.toHexString(b);
} // hex string to uppercase
m_szUniqueID = m_szUniqueID.toUpperCase();
要领封装:
public static String getIMEI(Context context)
{
TelephonyManager TelephonyMgr = (TelephonyManager)context.getSystemService(TELEPHONY_SERVICE);
String szImei = TelephonyMgr.getDeviceId();
String m_szDevIDShort = "35" + //we make this look like a valid IMEI
Build.BOARD.length()%10 + Build.BRAND.length()%10 +
Build.CPU_ABI.length()%10 + Build.DEVICE.length()%10 +
Build.DISPLAY.length()%10 + Build.HOST.length()%10 +
Build.ID.length()%10 + Build.MANUFACTURER.length()%10 +
Build.MODEL.length()%10 + Build.PRODUCT.length()%10 +
Build.TAGS.length()%10 + Build.TYPE.length()%10 + Build.USER.length()%10 ; //13 digits
String m_szAndroidID = Secure.getString(context.getContentResolver(), Secure.ANDROID_ID);
WifiManager wm = (WifiManager)context.getSystemService(Context.WIFI_SERVICE);
String m_szWLANMAC = wm.getConnectionInfo().getMacAddress();
BluetoothAdapter m_BluetoothAdapter = BluetoothAdapter.getDefaultAdapter();; // Local Bluetooth adapter
String m_szBTMAC = m_BluetoothAdapter.getAddress();
String m_szLongID = szImei + m_szDevIDShort + m_szAndroidID+ m_szWLANMAC + m_szBTMAC;
// compute md5
MessageDigest m = null;
try {
m = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
m.update(m_szLongID.getBytes(),0,m_szLongID.length());
// get md5 bytes
byte p_md5Data[] = m.digest();
// create a hex string
String m_szUniqueID = new String();
for (int i=0;i<p_md5Data.length;i++) {
int b = (0xFF & p_md5Data[i]);
// if it is a single digit, make sure it have 0 in front (proper padding)
if (b <= 0xF)
m_szUniqueID+="0";
// add number to string
m_szUniqueID+=Integer.toHexString(b);
} // hex string to uppercase
m_szUniqueID = m_szUniqueID.toUpperCase();
return m_szUniqueID;
}
通过以上算法,可发生32位的16进制数据:
9DDDF85AFF0A87974CE4541BD94D5F55
现在你便对其引入你的运用了。
上篇:上一篇:Android中ActionBar和ToolBar添加返回箭头
下篇:下一篇:Android 之 SeekBar用法介绍