facial_liveness_detection_flutter_plugin 1.0.0 copy "facial_liveness_detection_flutter_plugin: ^1.0.0" to clipboard
facial_liveness_detection_flutter_plugin: ^1.0.0 copied to clipboard

retractedoutdated

人脸活体检测,支持静默,炫彩,眨眼,张嘴,摇头,点头,远近及随意动作组合,支持Android,IOS,H5,小程序等

example/lib/main.dart

import 'dart:convert';

import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutter/services.dart';
import 'package:facial_liveness_detection_flutter_plugin/facial_liveness_detection_flutter_plugin.dart';
import 'package:http/http.dart' as http;
import 'dart:math';

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 = 'Unknown';
  final _FacialLivenessDetectionFlutterPluginPlugin = FacialLivenessDetectionFlutterPlugin();

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

  // Platform messages are asynchronous, so we initialize in an async method.
  Future<void> initPlatformState() async {
    String platformVersion;
    // Platform messages may fail, so we use a try/catch PlatformException.
    // We also handle the message potentially returning null.
    try {
      _FacialLivenessDetectionFlutterPluginPlugin.initEngine();
    } on PlatformException {
      platformVersion = 'Failed to get platform version.';
    }

    // If the widget was removed from the tree while the asynchronous platform
    // message was in flight, we want to discard the reply rather than calling
    // setState to update our non-existent appearance.
    if (!mounted) return;
  }

  String generateRandomNonce() {
    // 生成随机数作为 X-Ca-Nonce 的值
    final random = Random();
    final nonce = random.nextInt(1000000);
    return nonce.toString();
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: const Text('Plugin examxxxple app'),
        ),
        body: Column(
          children:[
            Text('Running on: $_platformVersion\n'),
            ElevatedButton(onPressed: () async {
              print('button pressed!');
              Map<String, dynamic> config = {
                "livingType": 23,
                "age": 30,
              };

              // 1. 认证初始化
              Map<String, dynamic> result = await _FacialLivenessDetectionFlutterPluginPlugin.verifyInit(config) ?? {};
              String code = result['code'];
              String initMsg = result['data'];
              print("code" + result['code']);
              print("msg" + result['msg']);
              print("data" + result['data']);
              if(code == "ELD_SUCCESS"){
                // 2. 获取认证授权
                final String apiUrl = 'http://eface.market.alicloudapi.com/init';
                final Map<String, String> headers = {
                  'Content-Type': 'application/x-www-form-urlencoded', // 设置请求头
                  'Authorization': 'APPCODE 替换为你的APPCODE', // 添加其他请求头字段 (注意不可泄露,建议通过服务器端请求网关,然后APP请求服务器端进行数据转发)
                  'X-Ca-Nonce': generateRandomNonce(), // 添加其他请求头字段
                };

                final Map<String, String> requestBody = {
                  'initMsg': initMsg,
                };

                final String encodedBody = requestBody.entries.map((entry) {
                  return '${entry.key}=${entry.value}';
                }).join('&');

                final response = await http.post(
                  Uri.parse(apiUrl),
                  headers: headers,
                  body: encodedBody,
                );

                if (response.statusCode == 200) {
                  print(response.body);
                  Map<String, dynamic> resultBody = json.decode(response.body);
                  // 3. 发起活体检测
                  Map<String, dynamic> resultxxx = await _FacialLivenessDetectionFlutterPluginPlugin.startLivingDetect({"token": resultBody['token'],
                  "cameraID": "REAR"}) ?? {};
                  print("code" + resultxxx['code']);
                  print("msg" + resultxxx['msg']);
                  print("data" + resultxxx['data']);
                  // 4. 获取认证结果
                  // TODO 
                } else {
                  throw Exception('Failed to make POST request');
                }
              }
            }, child: Text('启动刷脸'))
          ]
        )
      ),
    );
  }
}
4
likes
0
points
191
downloads

Publisher

verified publisheresandinfo.com

Weekly Downloads

人脸活体检测,支持静默,炫彩,眨眼,张嘴,摇头,点头,远近及随意动作组合,支持Android,IOS,H5,小程序等

Homepage

License

unknown (license)

Dependencies

flutter, plugin_platform_interface

More

Packages that depend on facial_liveness_detection_flutter_plugin

Packages that implement facial_liveness_detection_flutter_plugin