马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
x
目录
1. 使用 Build.SERIAL (适用于 Android 8.0 及以下)
2. 使用 Settings.Secure 获取 ANDROID_ID (适用于 Android 2.3 及以上)
3. 使用 TelephonyManager 获取装备的 IMEI (仅适用于带有电话功能的装备,且必要权限)
权限:
4. 获取装备的唯一 ID 示例代码(集成多个方法)
代码阐明:
注意事项:
输出结果:
1. 使用 Build.SERIAL (适用于 Android 8.0 及以下)
- // 获取设备的序列号
- String deviceSerial = Build.SERIAL;
复制代码 2. 使用 Settings.Secure 获取 ANDROID_ID (适用于 Android 2.3 及以上)
- // 获取 ANDROID_ID,通常唯一,但有时会被重置
- String androidId = Settings.Secure.getString(getContentResolver(), Settings.Secure.ANDROID_ID);
复制代码 3. 使用 TelephonyManager 获取装备的 IMEI (仅适用于带有电话功能的装备,且必要权限)
在 Android 6.0 及以上,必要动态请求权限。
权限:
在 AndroidManifest.xml 中声明权限:
- <uses-permission android:name="android.permission.READ_PHONE_STATE" />
复制代码 请求动态权限:
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
- if (checkSelfPermission(Manifest.permission.READ_PHONE_STATE) != PackageManager.PERMISSION_GRANTED) {
- requestPermissions(new String[]{Manifest.permission.READ_PHONE_STATE}, 1);
- }
- }
复制代码 获取 IMEI:
- // 获取 TelephonyManager 实例
- TelephonyManager telephonyManager = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);
- // 检查权限
- if (ActivityCompat.checkSelfPermission(this, Manifest.permission.READ_PHONE_STATE) == PackageManager.PERMISSION_GRANTED) {
- // 获取 IMEI 号码 (Android 10 及以上不推荐使用)
- String imei = telephonyManager.getDeviceId();
- }
复制代码 4. 获取装备的唯一 ID 示例代码(集成多个方法)
以下是获取装备唯一ID的完整示例代码,结合了 ANDROID_ID、Build.SERIAL 和 TelephonyManager:
- import android.Manifest;
- import android.content.Context;
- import android.content.pm.PackageManager;
- import android.os.Build;
- import android.provider.Settings;
- import android.telephony.TelephonyManager;
- import android.util.Log;
- import androidx.core.app.ActivityCompat;
- public class DeviceIdHelper {
- // 获取设备唯一ID的主方法
- public static String getDeviceId(Context context) {
- String deviceId = null;
- // 优先使用 ANDROID_ID
- deviceId = getAndroidId(context);
- if (deviceId != null && !deviceId.isEmpty()) {
- Log.d("DeviceIdHelper", "ANDROID_ID: " + deviceId);
- return deviceId;
- }
- // 如果 ANDROID_ID 不可用,使用序列号
- if (Build.VERSION.SDK_INT <= Build.VERSION_CODES.O) {
- deviceId = getDeviceSerial();
- if (deviceId != null && !deviceId.isEmpty()) {
- Log.d("DeviceIdHelper", "SERIAL: " + deviceId);
- return deviceId;
- }
- }
- // 尝试使用 IMEI (需要 READ_PHONE_STATE 权限)
- if (ActivityCompat.checkSelfPermission(context, Manifest.permission.READ_PHONE_STATE) == PackageManager.PERMISSION_GRANTED) {
- deviceId = getIMEI(context);
- if (deviceId != null && !deviceId.isEmpty()) {
- Log.d("DeviceIdHelper", "IMEI: " + deviceId);
- return deviceId;
- }
- }
- Log.d("DeviceIdHelper", "设备ID获取失败");
- return "Unknown";
- }
- // 获取 ANDROID_ID
- private static String getAndroidId(Context context) {
- return Settings.Secure.getString(context.getContentResolver(), Settings.Secure.ANDROID_ID);
- }
- // 获取设备序列号 (适用于 Android 8.0 及以下)
- private static String getDeviceSerial() {
- if (Build.VERSION.SDK_INT <= Build.VERSION_CODES.O) {
- return Build.SERIAL;
- } else {
- return Build.getSerial();
- }
- }
- // 获取 IMEI 号码 (仅在电话功能设备上有效)
- private static String getIMEI(Context context) {
- TelephonyManager telephonyManager = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);
- if (ActivityCompat.checkSelfPermission(context, Manifest.permission.READ_PHONE_STATE) == PackageManager.PERMISSION_GRANTED) {
- return telephonyManager.getDeviceId();
- }
- return null;
- }
- }
复制代码 代码阐明:
- getAndroidId():这是最常用的方法,返回装备的 ANDROID_ID,它通常是唯一的,但某些装备在重置后可能会更改。
- getDeviceSerial():获取装备的序列号,适用于 Android 8.0 及以下。Android 9.0 后谷歌不推荐使用序列号作为唯一标识。
- getIMEI():通过 TelephonyManager 获取装备的 IMEI 号码,必要权限,适用于有电话功能的装备。
- 权限管理:代码中包罗了动态权限请求的部分,确保在 Android 6.0 及以上版本获取 IMEI 时不会崩溃。
注意事项:
- 从 Android 10 开始,获取装备的 IMEI 和序列号已被限制,应用步伐无法再使用 TelephonyManager.getDeviceId() 和 Build.getSerial() 获取这些信息。APP 开发者通常使用 ANDROID_ID 作为装备的唯一标识符。
- 权限获取是必要的,对于 IMEI 这样的敏感信息,必要在应用的运行时动态请求权限。
输出结果:
根据装备情况,调用 getDeviceId() 方法会返回:
- ANDROID_ID(优先使用)。
- 序列号(如果适用)。
- IMEI(如果有权限且装备支持)。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |