Flutter设备唯一标识符插件immutable_device_identifier的使用

发布于 1周前 作者 yibo5220 来自 Flutter

Flutter设备唯一标识符插件 immutable_device_identifier 的使用

immutable_device_identifier 插件为iOS和Android设备提供了唯一标识符。该标识符在重新安装应用程序时不会改变。

使用方法

要获取设备的唯一标识符,可以使用以下代码:

final uniqueId = ImmutableDeviceIdentifier().getUniqueId();

iOS 实现细节

在iOS中,通过UUID和Keychain来保证每次重新安装后的返回值不变性。以下是Swift代码示例:

let key = "studio.creche.immutable_device_identifier/unique_id"

var uuid = try? self.keychain.get(key)
if (uuid ?? "").isEmpty {
  uuid = UUID().uuidString
  try? self.keychain.set(uuid ?? "", key: key)
}

Android 实现细节

在Android中,通过MediaDrm来保证每次重新安装后的返回值不变性。以下是Kotlin代码示例:

val uuid = UUID.fromString("edef8ba9-79d6-4ace-a3c8-27dcd51d21ed")
val id = MediaDrm(uuid).getPropertyByteArray(MediaDrm.PROPERTY_DEVICE_UNIQUE_ID)
val uniqueId = id.joinToString(":") { String.format("%02X", it) }

示例 Demo

以下是一个完整的Flutter应用示例,展示了如何使用immutable_device_identifier插件来获取设备的唯一标识符:

import 'package:flutter/material.dart';
import 'dart:async';

import 'package:flutter/services.dart';
import 'package:immutable_device_identifier/immutable_device_identifier.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatefulWidget {
  const MyApp({Key? key}) : super(key: key);

  [@override](/user/override)
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  String _platformVersion = 'Unknown';
  final _immutableDeviceIdentifierPlugin = ImmutableDeviceIdentifier();

  [@override](/user/override)
  void initState() {
    super.initState();
    initPlatformState();
  }

  // 异步初始化平台消息
  Future<void> initPlatformState() async {
    String platformVersion;
    try {
      platformVersion = await _immutableDeviceIdentifierPlugin.getUniqueId();
    } on PlatformException {
      platformVersion = 'Failed to get platform version.';
    }

    if (!mounted) return;

    setState(() {
      _platformVersion = platformVersion;
    });
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: const Text('Plugin example app'),
        ),
        body: Center(
          child: Text('Running on: $_platformVersion\n'),
        ),
      ),
    );
  }
}

更多关于Flutter设备唯一标识符插件immutable_device_identifier的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter设备唯一标识符插件immutable_device_identifier的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


当然,以下是如何在Flutter项目中使用immutable_device_identifier插件来获取设备唯一标识符的示例代码。

首先,确保你已经在pubspec.yaml文件中添加了immutable_device_identifier依赖:

dependencies:
  flutter:
    sdk: flutter
  immutable_device_identifier: ^x.y.z  # 请替换为最新版本号

然后运行flutter pub get来安装依赖。

接下来,在你的Flutter项目中,你可以按照以下步骤使用immutable_device_identifier插件:

  1. 导入插件

在你的Dart文件中导入插件:

import 'package:immutable_device_identifier/immutable_device_identifier.dart';
  1. 获取设备唯一标识符

使用ImmutableDeviceIdentifier类的getID方法获取设备唯一标识符。以下是一个完整的示例:

import 'package:flutter/material.dart';
import 'package:immutable_device_identifier/immutable_device_identifier.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  String? deviceId;

  @override
  void initState() {
    super.initState();
    _getDeviceID();
  }

  Future<void> _getDeviceID() async {
    try {
      String id = await ImmutableDeviceIdentifier.getID;
      setState(() {
        deviceId = id;
      });
    } catch (e) {
      print('Error getting device ID: $e');
    }
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('Device ID Example'),
        ),
        body: Center(
          child: Text(
            deviceId ?? 'Loading device ID...',
            style: TextStyle(fontSize: 24),
          ),
        ),
      ),
    );
  }
}

在这个示例中,我们创建了一个简单的Flutter应用,该应用在启动时调用_getDeviceID方法来获取设备的唯一标识符,并将其显示在屏幕上。

注意

  • 获取设备唯一标识符可能会受到操作系统和权限设置的限制。
  • 在iOS上,从iOS 14开始,获取设备标识符(如IDFA)需要用户的明确许可,并且可能会受到App Tracking Transparency(ATT)框架的限制。
  • 在Android上,从Android 10(API级别29)开始,获取某些硬件标识符(如IMEI和序列号)被限制或禁止,因此插件可能会使用其他方法来生成一个尽可能唯一的标识符。

请确保在实际应用中处理可能的错误和异常情况,并根据需要调整UI和逻辑。

回到顶部