Flutter身份验证与授权插件fusionauth_dart_client的使用

Flutter身份验证与授权插件fusionauth_dart_client的使用

如果您正在将FusionAuth集成到您的Dart或Flutter应用中,此库将加快您的开发速度。

有关FusionAuth的更多信息和文档,请参阅https://fusionauth.io

这是一个为FusionAuth Dart开发者准备的库。

已知限制

  • 由于缺少对动态字段的支持(例如JWT上的自定义声明),某些对象的使用受到限制。目前,除非类被显式子类化以包含这些字段,否则任何放在JSON中的数据在Dart中都不会呈现。

使用

以下是一个简单的使用示例:

import 'dart:convert';

import 'package:fusionauth_dart_client/fusionauth_dart_client.dart';

void main() async {
  // 初始化客户端
  var client = FusionAuthClient('bf69486b-4733-4470-a592-f1bfce7af580',
      'https://local.fusionauth.io', null);

  // 发送查询请求以搜索用户
  var response = await client.searchUsersByQuery(SearchRequest(
      search: UserSearchCriteria(queryString: 'email:test@example.com')));

  // 检查响应是否成功,并打印结果
  if (response.successResponse != null) {
    print(json.encode(response.successResponse.users));
  }
}

pubspec.yaml文件中添加依赖项:

dependencies:
  fusionauth_dart_client: ^1.21.0

贡献者

  • Dmitriy Scherbakov/sherbacov 添加了身份验证示例。

问题和支持

如果您有任何关于此客户端库的问题或支持需求,我们非常乐意听到您的声音。

如果您拥有包含支持的付费版本,请通过您的账户门户打开一个工单。了解更多关于付费版本的信息在这里

否则,请在社区论坛中发布您的问题

贡献

欢迎在GitHub上提交错误报告和拉取请求,地址为https://github.com/FusionAuth/fusionauth-dart-client

许可证

此代码根据Apache v2.0许可证作为开源软件提供。


示例代码

以下是从GitHub中获取的示例代码:

import 'dart:convert';

import 'package:fusionauth_dart_client/fusionauth_dart_client.dart';

void main() async {
  // 初始化客户端
  var client = FusionAuthClient('bf69486b-4733-4470-a592-f1bfce7af580',
      'https://local.fusionauth.io', null);

  // 发送查询请求以搜索用户
  var response = await client.searchUsersByQuery(SearchRequest(
      search: UserSearchCriteria(queryString: 'email:test@example.com')));

  // 检查响应是否成功,并打印结果
  if (response.successResponse != null) {
    print(json.encode(response.successResponse.users));
  }
}

更多关于Flutter身份验证与授权插件fusionauth_dart_client的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter身份验证与授权插件fusionauth_dart_client的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


fusionauth_dart_client 是一个用于与 FusionAuth 身份验证与授权服务进行交互的 Dart 客户端库。它可以帮助你在 Flutter 应用中轻松实现用户身份验证、授权、用户管理等功能。

以下是如何在 Flutter 项目中使用 fusionauth_dart_client 的基本步骤:

1. 添加依赖

首先,你需要在 pubspec.yaml 文件中添加 fusionauth_dart_client 依赖:

dependencies:
  flutter:
    sdk: flutter
  fusionauth_dart_client: ^1.0.0  # 请检查最新版本

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

2. 导入库

在你的 Dart 文件中导入 fusionauth_dart_client

import 'package:fusionauth_dart_client/fusionauth_dart_client.dart';

3. 创建 FusionAuth 客户端

你需要使用你的 FusionAuth API 密钥和 FusionAuth 服务器地址来创建客户端:

final client = FusionAuthClient(
  apiKey: 'your-api-key',
  basePath: 'https://your-fusionauth-server-url',
);

4. 用户注册

你可以使用 register 方法来注册新用户:

final registrationRequest = RegistrationRequest(
  user: User(
    email: 'user@example.com',
    password: 'password',
  ),
  applicationId: 'your-application-id',
);

final response = await client.register(registrationRequest);
if (response.statusCode == 200) {
  print('User registered successfully');
} else {
  print('Failed to register user: ${response.errorResponse}');
}

5. 用户登录

使用 login 方法进行用户登录:

final loginRequest = LoginRequest(
  loginId: 'user@example.com',
  password: 'password',
  applicationId: 'your-application-id',
);

final response = await client.login(loginRequest);
if (response.statusCode == 200) {
  print('User logged in successfully');
  print('Token: ${response.successResponse.token}');
} else {
  print('Failed to login: ${response.errorResponse}');
}

6. 获取用户信息

你可以使用 retrieveUser 方法来获取用户信息:

final userId = 'user-id'; // 用户在 FusionAuth 中的唯一 ID
final response = await client.retrieveUser(userId);
if (response.statusCode == 200) {
  print('User info: ${response.successResponse.user}');
} else {
  print('Failed to retrieve user info: ${response.errorResponse}');
}

7. 刷新 Token

如果用户的访问令牌过期,你可以使用 refreshToken 方法来刷新令牌:

final refreshRequest = RefreshRequest(
  refreshToken: 'refresh-token',
);

final response = await client.refreshToken(refreshRequest);
if (response.statusCode == 200) {
  print('Token refreshed successfully');
  print('New token: ${response.successResponse.token}');
} else {
  print('Failed to refresh token: ${response.errorResponse}');
}

8. 用户注销

使用 logout 方法进行用户注销:

final logoutRequest = LogoutRequest(
  refreshToken: 'refresh-token',
);

final response = await client.logout(logoutRequest);
if (response.statusCode == 200) {
  print('User logged out successfully');
} else {
  print('Failed to logout: ${response.errorResponse}');
}
回到顶部