Flutter指纹认证插件mercadolibre_fingerprint的使用

MercadoLibre Fingerprint #

插件用于获取设备的所有指纹信息。

为了获取MercadoLibre用于令牌化卡所需的所有设备指纹信息(https://www.mercadopago.cl/developers/es/docs/checkout-pro/how-tos/payment-approval),你可以在Android和iOS上获取这些信息。

使用 #

import 'package:mercadolibre_fingerprint/mercadolibre_fingerprint.dart';

// 返回设备指纹信息的JSON字符串 MercadolibreFingerprint().getDeviceInfoAsJsonString();

贡献 #

欢迎提交拉取请求。对于重大更改,请先打开一个问题讨论你想要进行的更改。

请确保相应地更新测试。

许可证 #

MIT

example/lib/main.dart

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

import ‘package:flutter/services.dart’; import ‘package:mercadolibre_fingerprint/mercadolibre_fingerprint.dart’;

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

class MyApp extends StatefulWidget { const MyApp({super.key});

@override State<MyApp> createState() => _MyAppState(); }

class _MyAppState extends State<MyApp> { String _platformVersion = ‘未知’; final _mercadolibreFingerprintPlugin = MercadolibreFingerprint();

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

// 平台消息是异步的,所以我们初始化在一个异步方法中。 Future<void> initPlatformState() async { String platformVersion; // 平台消息可能会失败,所以我们使用一个try/catch PlatformException。 // 我们还处理消息可能返回null的情况。 try { platformVersion = await _mercadolibreFingerprintPlugin.getDeviceInfoAsJsonString() ?? ‘未知平台版本’; } on PlatformException { platformVersion = ‘获取平台版本失败。’; }

// 如果小部件在异步平台消息飞行时从树中移除,我们希望丢弃回复而不是调用
// setState来更新我们的不存在的外观。
if (!mounted) return;

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

}

@override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( appBar: AppBar( title: const Text(‘插件示例应用’), ), body: Center( child: Text(‘运行于: $_platformVersion\n’), ), ), ); } }


更多关于Flutter指纹认证插件mercadolibre_fingerprint的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter指纹认证插件mercadolibre_fingerprint的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


mercadolibre_fingerprint 是一个用于在 Flutter 应用中实现指纹认证的插件。它允许开发者集成指纹认证功能,以增强应用的安全性。以下是如何在 Flutter 项目中使用 mercadolibre_fingerprint 插件的步骤:

1. 添加依赖

首先,在 pubspec.yaml 文件中添加 mercadolibre_fingerprint 插件的依赖:

dependencies:
  flutter:
    sdk: flutter
  mercadolibre_fingerprint: ^1.0.0  # 请使用最新版本

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

2. 导入插件

在需要使用指纹认证功能的 Dart 文件中导入插件:

import 'package:mercadolibre_fingerprint/mercadolibre_fingerprint.dart';

3. 初始化插件

在应用启动时,初始化指纹认证插件:

void main() async {
  WidgetsFlutterBinding.ensureInitialized();
  await MercadolibreFingerprint.initialize();
  runApp(MyApp());
}

4. 检查设备支持

在调用指纹认证之前,检查设备是否支持指纹认证功能:

bool isSupported = await MercadolibreFingerprint.isSupported();
if (isSupported) {
  print("设备支持指纹认证");
} else {
  print("设备不支持指纹认证");
}

5. 进行指纹认证

调用 authenticate 方法进行指纹认证:

try {
  bool authenticated = await MercadolibreFingerprint.authenticate(
    localizedReason: '请验证指纹以继续',
    useErrorDialogs: true,
    stickyAuth: false,
  );

  if (authenticated) {
    print("指纹认证成功");
  } else {
    print("指纹认证失败");
  }
} catch (e) {
  print("指纹认证出错: $e");
}

6. 处理认证结果

根据认证结果执行相应的操作。例如,如果认证成功,可以导航到应用的某个页面;如果认证失败,可以显示错误信息。

7. 自定义认证对话框(可选)

你可以通过 localizedReason 参数自定义指纹认证对话框的提示信息。useErrorDialogs 参数控制是否显示系统默认的错误对话框,stickyAuth 参数控制认证失败后是否保持认证状态。

8. 处理异常

在指纹认证过程中,可能会抛出异常。建议在 try-catch 块中捕获并处理这些异常,以确保应用的稳定性。

9. 清理资源(可选)

如果你在应用中不再需要指纹认证功能,可以调用 deinitialize 方法清理资源:

await MercadolibreFingerprint.deinitialize();

10. 示例代码

以下是一个完整的示例代码,展示了如何在 Flutter 应用中使用 mercadolibre_fingerprint 插件进行指纹认证:

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

void main() async {
  WidgetsFlutterBinding.ensureInitialized();
  await MercadolibreFingerprint.initialize();
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      home: FingerprintAuthScreen(),
    );
  }
}

class FingerprintAuthScreen extends StatelessWidget {
  Future<void> _authenticate() async {
    try {
      bool isSupported = await MercadolibreFingerprint.isSupported();
      if (isSupported) {
        bool authenticated = await MercadolibreFingerprint.authenticate(
          localizedReason: '请验证指纹以继续',
          useErrorDialogs: true,
          stickyAuth: false,
        );

        if (authenticated) {
          print("指纹认证成功");
        } else {
          print("指纹认证失败");
        }
      } else {
        print("设备不支持指纹认证");
      }
    } catch (e) {
      print("指纹认证出错: $e");
    }
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('指纹认证示例'),
      ),
      body: Center(
        child: ElevatedButton(
          onPressed: _authenticate,
          child: Text('验证指纹'),
        ),
      ),
    );
  }
}
回到顶部