有很多場景和需求你需要用到手機設備的唯一標識符。
在Android中,有以下幾種方法獲取這樣的ID。
1. The IMEI: 僅僅只對Android手機有效:
采用此種方法,需要在AndroidManifest.xml中加入一個許可:android.permission.READ_PHONE_STATE,並且用戶應當允許安裝此應用。作為手機來講,IMEI是唯一的,它應該類似於 359881030314356(除非你有一個沒有量產的手機(水貨)它可能有無效的IMEI,如:0000000000000)。
2. Pseudo-Unique ID, 這個在任何Android手機中都有效
有一些特殊的情況,一些如平板電腦的設置沒有通話功能,或者你不願加入READ_PHONE_STATE許可。而你仍然想獲得唯一序列號之類的東西。這時你可以通過取出ROM版本、制造商、CPU型號、以及其他硬件信息來實現這一點。這樣計算出來的ID不是唯一的(因為如果兩個手機應用了同樣的硬件以及Rom 鏡像)。但應當明白的是,出現類似情況的可能性基本可以忽略。要實現這一點,你可以使用Build類:
大多數的Build成員都是字符串形式的,我們只取他們的長度信息。我們取到13個數字,並在前面加上“35”。這樣這個ID看起來就和15位IMEI一樣了。
3. The Android ID
通常被認為不可信,因為它有時為null。開發文檔中說明了:這個ID會改變如果進行了出廠設置。並且,如果某個Andorid手機被Root過的話,這個ID也可以被任意改變。
Returns: 9774d56d682e549c . 無需任何許可。
4. The WLAN MAC Address string
是另一個唯一ID。但是你需要為你的工程加入android.permission.ACCESS_WIFI_STATE 權限,否則這個地址會為null。
Returns: 00:11:22:33:44:55 (這不是一個真實的地址。而且這個地址能輕易地被偽造。).WLan不必打開,就可讀取些值。
5. The BT MAC Address string
只在有藍牙的設備上運行。並且要加入android.permission.BLUETOOTH 權限.
Returns: 43:25:78:50:93:38 . 藍牙沒有必要打開,也能讀取。
Combined Device ID
綜上所述,我們一共有五種方式取得設備的唯一標識。它們中的一些可能會返回null,或者由於硬件缺失、權限問題等獲取失敗。
但你總能獲得至少一個能用。所以,最好的方法就是通過拼接,或者拼接后的計算出的MD5值來產生一個結果。
通過以上算法,可產生32位的16進制數據:
9DDDF85AFF0A87974CE4541BD94D5F55
現在你就可以對其進行你的應用了。
//---------------------------------------------------------------------
android下獲取設備唯一標識原本非常簡單(至少不會像iOS一樣禁用這個,禁用那個),但是由於設備的多樣性需要考慮的東西也對應復雜起來。
先附上完整代碼
java代碼
- protected static final String PREFS_FILE =
- "gank_device_id.xml";
- protected static final String PREFS_DEVICE_ID = "gank_device_id";
- protected static String uuid;
- static public String getUDID()
- {
- if( uuid ==null ) {
- synchronized (GankMainActivity.class) {
- if( uuid == null) {
- final SharedPreferences prefs = s_instance.getSharedPreferences(
- PREFS_FILE, 0);
- final String id = prefs.getString(PREFS_DEVICE_ID, null );
- if (id != null) {
- // Use the ids previously computed and stored in the prefs file
- uuid = id;
- } else {
- final String androidId = Secure.getString(s_instance.getContentResolver(),
- Secure.ANDROID_ID);
- // Use the Android ID unless it's broken, in which case fallback on
- deviceId,
- // unless it's not available, then fallback on a random number which we
- store
- // to a prefs file
- try {
- if (!"9774d56d682e549c".equals(androidId)) {
- uuid = UUID.nameUUIDFromBytes(androidId.getBytes("utf8")).toString();
- } else {
- final String deviceId = ((TelephonyManager) s_instance.getSystemService(
- Context.TELEPHONY_SERVICE )).getDeviceId();
- uuid = deviceId!=null ?
- UUID.nameUUIDFromBytes(deviceId.getBytes("utf8")).toString() :
- UUID.randomUUID().toString();
- }
- } catch (UnsupportedEncodingException e) {
- throw new RuntimeException(e);
- }
- // Write the value out to the prefs file
- prefs.edit().putString(PREFS_DEVICE_ID, uuid).commit();
- }
- }
- }
- }
- return uuid;
- }
1、正常情況下可以通過((TelephonyManager) s_instance.getSystemService( Context.TELEPHONY_SERVICE )).getDeviceId(); 來獲取,但是某些平板電腦此函數會返回空
2、通過 Secure.getString(s_instance.getContentResolver(), Secure.ANDROID_ID); 也可以獲取到一個id,但是android2.2或者是某些山寨手機使用這個也是有問題的,它會返回一個固定的值 9774d56d682e549c
3、如果前兩個都沒有獲取到udid,那么就在程序啟動的時候創建一個隨機的uuid,然后保存起來。這個算是兼容方案,當然這樣的設備並不會很多。
原文鏈接:http://www.eyeandroid.com/thread-15908-1-1.html