Android Q 禁止获取 IMEI 和设备序列号; 官方的解决方案是这样:https://developer.android.com/training/articles/user-data-ids 结合官方实现方案和实际需求自己整理的实现方法如下: 方案一: /** * 获
Android Q 禁止获取 IMEI 和设备序列号;
官方的解决方案是这样:https://developer.android.com/training/articles/user-data-ids
结合官方实现方案和实际需求自己整理的实现方法如下:
方案一:
/** * 获取设备唯一标识符 * * @return 唯一标识符 */ public static String getDeviceId() { // 通过 SharedPreferences 获取 GUID String guid = SPUtils.getInstance().getString(AppConfig.SP_GUID); if (!TextUtils.isEmpty(guid)) { return guid; } // 获取 ANDROID_ID String android_id = Settings.System.getString( App.getApp().getContentResolver(), Settings.Secure.ANDROID_ID); if (!TextUtils.isEmpty(android_id)) { // 通过 ANDROID_ID 生成 guid(唯一标识符) guid = EncryptUtils.encryptMD5ToString(android_id); } else { // 通过 UUID 生成 guid(唯一标识符) guid = EncryptUtils.encryptMD5ToString(UUID.randomUUID().toString()); } // 保存 guid 到 SharedPreferences SPUtils.getInstance().put(AppConfig.SP_GUID, guid); return guid; }
上面 SPUtils 是自己封装的 SharedPreferences 的一个工具类。
方案二:
/** * 获取设备唯一标识符 * * @return 唯一标识符 */ @SuppressLint("HardwareIds") public static String getDeviceId() { String m_szDevIDShort = "35" + 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 位 String serial = "serial";// 默认serial可随便定义 try { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { if (ActivityCompat.checkSelfPermission(App.getApp(), Manifest.permission.READ_PHONE_STATE) == PackageManager.PERMISSION_GRANTED) { // 由于 Android Q 唯一标识符权限的更改会导致 // android.os.Build.getSerial() 返回 unknown, // 但是 m_szDevIDShort 是由硬件信息拼出来的,所以仍然保证了UUID 的唯一性和持久性。 serial = android.os.Build.getSerial();// Android Q 中返回 unknown } } else { serial = Build.SERIAL; } } catch (Exception ignored) { } return new UUID(m_szDevIDShort.hashCode(), serial.hashCode()).toString(); }
由于m_szDevIDShort是由硬件信息拼出来的,所以保证了UUID的唯一性和持久性。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。