Flutter门禁管理插件flutter_zkteco的使用

Flutter门禁管理插件flutter_zkteco的使用

特性

  • 通过TCP/IP连接到指纹识别设备
  • 获取用户信息(如ID、姓名等)
  • 获取考勤记录(时间戳、用户ID等)
  • 支持实时数据和批量数据获取
  • 兼容ZKTeco及类似设备

开始使用

安装

在你的项目pubspec.yaml文件中添加以下依赖:

dependencies:
  flutter_zkteco: ^1.0.2

然后运行:

flutter pub get

平台支持

  • Android
  • iOS
  • Web (待定)
  • Windows

使用方法

导入包

import 'package:flutter_zkteco/flutter_zkteco.dart';

初始化插件

// 创建一个ZKTeco实例
ZKTeco fingerprintMachine = ZKTeco('192.168.1.201', port: 4370);

// 初始化连接
bool isConnected = await fingerprintMachine.connect();
if (isConnected) {
  print('Connection established!');
} else {
  print('Connection failed!');
}

获取考勤记录

// 从机器获取考勤记录
List<AttendanceLog> logs = await fingerprintMachine.getAttendanceLogs();
for (var log in logs) {
  print('User ID: ${log.id}, Timestamp: ${log.timestamp}');
}

获取用户信息

// 从指纹机获取用户信息
List<UserInfo> users = await fingerprintMachine.getUsers();
for (var user in users) {
  print('User ID: ${user.userId}, Name: ${user.name}');
}

断开连接

await fingerprintMachine.disconnect();
print('Disconnected from the fingerprint machine.');

示例

下面是一个完整的示例,演示如何连接、获取数据并断开连接:

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

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      title: '指纹机演示',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  [@override](/user/override)
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  ZKTeco fingerprintMachine;
  List<AttendanceLog> logs = [];

  [@override](/user/override)
  void initState() {
    super.initState();
    fingerprintMachine = ZKTeco('192.168.1.201', port: 4370);
  }

  Future<void> connectAndFetchLogs() async {
    bool isConnected = await fingerprintMachine.connect();
    if (isConnected) {
      List<AttendanceLog> fetchedLogs = await fingerprintMachine.getAttendanceLogs();
      setState(() {
        logs = fetchedLogs;
      });
      await fingerprintMachine.disconnect();
    } else {
      print('Failed to connect.');
    }
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('指纹考勤记录'),
      ),
      body: Center(
        child: Column(
          children: [
            ElevatedButton(
              onPressed: connectAndFetchLogs,
              child: Text('获取记录'),
            ),
            Expanded(
              child: ListView.builder(
                itemCount: logs.length,
                itemBuilder: (context, index) {
                  return ListTile(
                    title: Text('User ID: ${logs[index].userId}'),
                    subtitle: Text('Timestamp: ${logs[index].timestamp}'),
                  );
                },
              ),
            ),
          ],
        ),
      ),
    );
  }
}

更多关于Flutter门禁管理插件flutter_zkteco的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter门禁管理插件flutter_zkteco的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


当然,以下是一个关于如何使用 flutter_zkteco 插件来进行门禁管理的示例代码。这个插件通常用于与 ZKTeco 的门禁设备进行交互。请注意,实际使用时你可能需要根据具体的设备和需求调整代码。

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

dependencies:
  flutter:
    sdk: flutter
  flutter_zkteco: ^最新版本号  # 请替换为实际的最新版本号

然后,运行 flutter pub get 来获取依赖。

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

  1. 初始化插件并连接到设备
import 'package:flutter/material.dart';
import 'package:flutter_zkteco/flutter_zkteco.dart';

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

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

class _MyAppState extends State<MyApp> {
  FlutterZKTeco? _zkteco;
  String _status = '未连接';

  @override
  void initState() {
    super.initState();
    _zkteco = FlutterZKTeco();
    _zkteco!.init()!.then((value) {
      if (value) {
        setState(() {
          _status = '已连接';
        });
        // 连接成功后,可以调用其他方法,比如获取用户信息等
      } else {
        setState(() {
          _status = '连接失败';
        });
      }
    }).catchError((error) {
      setState(() {
        _status = '初始化错误: $error';
      });
    });
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('Flutter ZKTeco 示例'),
        ),
        body: Center(
          child: Text('设备状态: $_status'),
        ),
      ),
    );
  }

  @override
  void dispose() {
    _zkteco?.dispose();
    super.dispose();
  }
}
  1. 获取用户信息

一旦连接成功,你可以调用其他方法来获取用户信息或执行其他操作。例如,获取所有用户信息:

Future<void> _getAllUsers() async {
  try {
    List<User> users = await _zkteco!.getAllUsers()!;
    // 处理用户信息
    users.forEach((user) {
      print('用户ID: ${user.userId}, 姓名: ${user.name}');
    });
  } catch (error) {
    print('获取用户信息失败: $error');
  }
}

你可以在按钮点击事件中调用这个方法:

FloatingActionButton(
  onPressed: () {
    _getAllUsers();
  },
  tooltip: '获取用户信息',
  child: Icon(Icons.people),
),
  1. 其他操作

根据 flutter_zkteco 插件的文档,你还可以执行其他操作,比如添加用户、删除用户、验证用户等。以下是一个简单的验证用户示例:

Future<void> _verifyUser(int userId, String password) async {
  try {
    bool result = await _zkteco!.verifyUser(userId, password)!;
    print('验证结果: $result');
  } catch (error) {
    print('验证用户失败: $error');
  }
}

同样,你可以在按钮点击事件中调用这个方法:

FloatingActionButton.small(
  onPressed: () {
    _verifyUser(12345, '123456'); // 替换为实际的用户ID和密码
  },
  tooltip: '验证用户',
  child: Icon(Icons.lock),
),

请注意,上述代码仅作为示例,实际使用时需要根据具体的设备和需求进行调整。此外,确保你已经正确配置了设备的 IP 地址、端口号以及其他必要的连接参数。

回到顶部