详解如何在Flutter中集成华为认证服务

最近发现华为AGC认证服务支持Flutter框架了,期待这个平台的支持已经很久了,所以迫不及待接入了,关联了自己的邮箱等账号。

集成步骤

安装flutter环境

a) 下载Flutter sdk包,地址:https://flutter.dev/docs/get-started/install/windows

将压缩包解压到任意文件夹,例如D:\Flutter

b) 将flutter命令文件添加到环境变量中,此处我添加的Path为D:\Flutter\flutter_windows_1.22.2-stable\flutter\bin。

c) 在Android Studio中点击“File-Settings-Plugins”,下载Flutter和Dart插件,重启Android Studio使插件生效。

开通服务&创建工程

a) 在AGC创建Android应用并开通认证服务

b) 开启认证服务中的匿名帐号,手机帐号,邮箱帐号

c) 在Android Studio中新建Flutter工程

d) 将agconnect-services.json文件放入Android/app目录下

e) 配置Maven仓地址和AGC插件地址。

a. 打开Flutter项目android文件夹下的build.gradle文件。

b. 在allprojects ->repositories里面配置maven仓地址。

c. 在buildscript->repositories中配置maven仓地址。

d. 在buildscript->dependencies中配置AppGallery Connect插件地址。

添加编译依赖和AGC插件地址。
a. 打开Flutter项目android/app文件夹下的build.gradle文件。
b. 在文件中添加如下配置。

集成SDK

在Flutter项目的pubspec.yaml文件中添加依赖:

dependencies:
  flutter:
  sdk: flutter
# Add the following line:
  agconnect_auth: ^1.1.0

然后点击Pub get进行同步

接入功能

匿名帐号登录

匿名帐号只需要调用signInAnonymously接口进行登录

_signIn() async {
 AGCAuth.instance.signInAnonymously().then((value) {
  setState(() {
   _log =
     'signInAnonymously = ${value.user.uid} , ${value.user.providerId}';
  });
 });
}

通过value,我们可以获取到用户信息,例如这里我们获取到了user的id。

手机号&邮箱认证

手机号邮箱账号认证首先需要发送验证码,

手机号请求验证码,即调用requestVerifyCode方法,传入手机号、国家码、设置项作为参数:

_requestPhoneVerifyCode(VerifyCodeAction action) {
 String countryCode = _countryCodeController.text;
 String phoneNumber = _phoneNumberController.text;
 VerifyCodeSettings settings = VerifyCodeSettings(action, sendInterval: 30);
 PhoneAuthProvider.requestVerifyCode(countryCode, phoneNumber, settings).then((value) => print(value.validityPeriod));
}

邮箱请求验证码,即调用requestVerifyCode方法,传入邮箱、设置项作为参数:

_requestEmailVerifyCode(VerifyCodeAction action) {
 String email = _emailController.text;
 VerifyCodeSettings settings = VerifyCodeSettings(action, sendInterval: 30);
 EmailAuthProvider.requestVerifyCode(email, settings)
   .then((value) => print(value.validityPeriod));
}

而后是创建用户的操作:

创建手机账号用户,需要调用createPhoneUser方法,传入封装好的PhoneUser对象

_createPhoneUser() async {
  bool result = await _showPhoneDialog(VerifyCodeAction.registerLogin);
  if (result == null) {
   print("cancel");
   return;
  }
  String countryCode = _countryCodeController.text;
  String phoneNumber = _phoneNumberController.text;
  String verifyCode = _verifyCodeController.text;
  String password = _passwordController.text;
  AGCAuth.instance.createPhoneUser(PhoneUser(countryCode, phoneNumber, verifyCode, password: password)) .then((value) {
   setState(() {
    _log = 'createPhoneUser = ${value.user.uid} , ${value.user.providerId}';
   });
  }).catchError((error)=>print(error));
 }

创建邮箱账号用户,需要调用createEmailUser方法,传入封装好的EmailUser对象。

_createEmailUser() async {
  bool result = await _showEmailDialog(VerifyCodeAction.registerLogin);
  if (result == null) {
   print("cancel");
   return;
  }
  String email = _emailController.text;
  String verifyCode = _verifyCodeController.text;
  String password = _passwordController.text;
  AGCAuth.instance
    .createEmailUser(EmailUser(email, verifyCode, password: password))
    .then((value) {
   setState(() {
    _log = 'createEmailUser = ${value.user.uid} , ${value.user.providerId}';
   });
  }).catchError((error) => print(error));
 }

最后是登录功能,有两种登录模式,一种是密码登录方式:

手机账号,调用signIn方法,传入使用手机号等生成的认证凭据。

_signInWithPassword() async {
  bool result = await _showPhoneDialog(VerifyCodeAction.registerLogin);
  if (result == null) {
   print("cancel");
   return;
  }
  String countryCode = _countryCodeController.text;
  String phoneNumber = _phoneNumberController.text;
  String password = _passwordController.text;
  AGCAuthCredential credential = PhoneAuthProvider.credentialWithPassword(countryCode, phoneNumber, password);
  AGCAuth.instance.signIn(credential).then((value) {
   setState(() {
    _log = 'signInWithPassword = ${value.user.uid} , ${value.user.providerId}';
   });
  });
 }

邮箱账号:调用signIn方法,传入通过邮箱和密码生成的认证凭据。

_signInWithPassword() async {
  bool result = await _showEmailDialog(VerifyCodeAction.registerLogin);
  if (result == null) {
   print("cancel");
   return;
  }
  String email = _emailController.text;
  String password = _passwordController.text;
  AGCAuthCredential credential =
    EmailAuthProvider.credentialWithPassword(email, password);
  AGCAuth.instance.signIn(credential).then((value) {
   setState(() {
    _log =
      'signInWithPassword = ${value.user.uid} , ${value.user.providerId}';
   });
  });
 }

另一种是验证码登录方式:

手机账号:调用signIn方法,传入通过手机、验证码和密码生成的认证凭据。

_signInWithVerifyCode() async {
  bool result = await _showPhoneDialog(VerifyCodeAction.registerLogin);
  if (result == null) {
   print("cancel");
   return;
  }
  String countryCode = _countryCodeController.text;
  String phoneNumber = _phoneNumberController.text;
  String verifyCode = _verifyCodeController.text;
  String password = _passwordController.text;
  AGCAuthCredential credential = PhoneAuthProvider.credentialWithVerifyCode(countryCode, phoneNumber, verifyCode, password: password);
  AGCAuth.instance.signIn(credential).then((value) {
   setState(() {
    _log = 'signInWithVerifyCode = ${value.user.uid} , ${value.user.providerId}';
   });
  });
 }

邮箱账号:调用signIn方法,传入通过邮箱、验证码和密码生成的认证凭据。

_signInWithVerifyCode() async {
  bool result = await _showEmailDialog(VerifyCodeAction.registerLogin);
  if (result == null) {
   print("cancel");
   return;
  }
  String email = _emailController.text;
  String verifyCode = _verifyCodeController.text;
  String password = _passwordController.text;
  AGCAuthCredential credential = EmailAuthProvider.credentialWithVerifyCode(
    email, verifyCode,
    password: password);
  AGCAuth.instance.signIn(credential).then((value) {
   setState(() {
    _log =
      'signInWithVerifyCode = ${value.user.uid} , ${value.user.providerId}';
   });
  });
 }

自有账号

自有账号创建jwt获取token等步骤为server端步骤,端侧只需要取到token进行登录即可。

_signIn() async {
  bool result = await _showSelfBuildDialog(VerifyCodeAction.registerLogin);
  if (result == null) {
   print("cancel");
   return;
  }
  String token = _selfBuildController.text;
  AGCAuthCredential credential = SelfBuildAuthProvider.credentialWithToken(token);
  AGCAuth.instance.signIn(credential).then((value) {
   setState(() {
    _log = 'signIn = ${value.user.uid} , ${value.user.providerId}';
   });
  });
 }

打包

与Android相同,只需要在Android Studio中点击运行即可

欲了解更多详情请参见:

认证服务开发指南:

https://developer.huawei.com/consumer/cn/doc/development/AppGallery-connect-Guides/agc-auth-introduction-0000001053732605

认证服务codelab(Android):

https://developer.huawei.com/consumer/cn/codelab/AuthenticationService/index.html#0

原文链接:https://developer.huawei.com/consumer/cn/forum/topic/0201436847294530241?fid=0101271690375130218

原作者:Mayism

到此这篇关于详解如何在Flutter中集成华为认证服务的文章就介绍到这了,更多相关Flutter集成华为认证服务内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Flutter应用集成极光推送的实现示例

    概述 在移动应用开发中,消息推送可以说是一项非常重要的功能,它能够起到提醒或者唤醒用户的作用,同时也是产品运营人员更高效地实现运营目标的重要手段,比如将新上架一个商品或者最新的一条新闻推送给用户. 事实上,消息推送是一个横跨业务服务器.第三方推送服务托管厂商.操作系统长连接推送服务.用户终端以及移动手机应用等五方面的复杂业务应用场景.在原生iOS开发中,为了简化消息推送,苹果推送服务(简称APNs)接管了系统所有应用的消息通知需求,任何第三方消息推送都需要经过推送服务进行转发.对于原生Andro

  • Flutter集成到已有iOS工程的方法步骤

    前言 之前写过一篇介绍flutter集成到Android工程的文章,这次总结记录一下自己把flutter集成到iOS的流程,以及遇到的问题以及和解决方法供大家参考. 创建flutter_module 要在iOS工程中集成flutter,首先我们需要创建一个flutter_module,创建的方法有两种: 使用Android studio创建 使用Android studio创建在上一篇新版Flutter集成到已有Android项目中有介绍,这里不再赘述. 使用flutter命令创建 在指定目录下

  • 新版Flutter集成到已有Android项目的实现

    FlutterSDK升级后,我们发现不能按照原来的方式集成到已有Android项目中了,因为没有了Flutter这个类,通过阅读源码我找到了新的使用方式. 一.创建Flutter Module 在已有Android工程中集成flutter,可以使用AndroidStudio的new Flutter Module实现,方便快捷. 找到FlutterModule,一连串的next操作即可 创建完成后我们的项目中会多一个叫做flutter的module 并且在项目的setting.gradle文件中会

  • 详解如何在Flutter中集成华为认证服务

    最近发现华为AGC认证服务支持Flutter框架了,期待这个平台的支持已经很久了,所以迫不及待接入了,关联了自己的邮箱等账号. 集成步骤 安装flutter环境 a) 下载Flutter sdk包,地址:https://flutter.dev/docs/get-started/install/windows 将压缩包解压到任意文件夹,例如D:\Flutter b) 将flutter命令文件添加到环境变量中,此处我添加的Path为D:\Flutter\flutter_windows_1.22.2-

  • 详解如何在Flutter中获取设备标识符

    目录 使用 platform_device_id 应用预览 代码 使用 device_info_plus 应用预览 代码 结论 本文将引导您完成 2 个示例,演示如何在 Flutter 中获取设备标识符 使用 platform_device_id 如果您只需要运行应用程序的设备的 id,最简单快捷的解决方案是使用platform_device_id包.它适用于 Android (AndroidId).iOS (IdentifierForVendor).Windows (BIOS UUID).ma

  • 详解如何在C#中使用投影(Projection)

    投影(Projection) 是一种可以将查询结果进行 塑性 的一种操作,你可以使用 投影 将一个 object 转成仅包含你需要属性的新对象,这篇文章中,我们就一起看看如何使用 投影 功能. C# 中的投影 LINQ 集成查询中有两个支持投影的扩展方法,分别为: Select 和 SelectMany 操作,可以用它们投影单个或者多个属性,或者投影查询的结果集到一个新的匿名类型中,还可以在投影的过程中执行: 再计算,过滤,或者其他一些必要的操作. Select 投影 为了演示目的,我先构造一个

  • 详解如何在Flutter中用小部件创建响应式布局

    目录 前提条件 使用容器的问题 展开式小组件的介绍 灵活小组件的介绍 设置一个示例应用程序 代码执行 扩展的小部件例子 灵活部件的例子 扩大的和灵活的部件之间的区别 总结 构建响应式屏幕布局意味着编写一段代码,以响应设备布局的各种变化,因此应用程序会根据设备的屏幕尺寸和形状显示其UI. 在这篇文章中,我们将探讨Flutter中用于屏幕响应的扩展和灵活部件. 由于Flutter的跨平台.单一代码库的能力,了解屏幕管理以防止像柔性溢出错误或糟糕的用户界面设计这样的问题是至关重要的. 我们还将设计一个

  • 详解如何在pyqt中通过OpenCV实现对窗口的透视变换

    窗口的透视变换效果    当我们点击Win10的UWP应用中的小部件时,会发现小部件会朝着鼠标点击位置凹陷下去,而且不同的点击位置对应着不同的凹陷情况,看起来就好像小部件在屏幕上不只有x轴和y轴,甚至还有一个z轴.要做到这一点,其实只要对窗口进行透视变换即可.下面是对Qt的窗口和按钮进行透视变换的效果: 具体代码    1.下面先定义一个类,它的作用是将传入的 QPixmap 转换为numpy 数组,然后用 opencv 的 warpPerspective 对数组进行透视变换,最后再将 nump

  • 详解如何在Javascript中使用Object.freeze()

    Object.freeze() Object.freeze() 方法可以冻结一个对象.一个被冻结的对象再也不能被修改:冻结了一个对象则不能向这个对象添加新的属性,不能删除已有属性,不能修改该对象已有属性的可枚举性.可配置性.可写性,以及不能修改已有属性的值.此外,冻结一个对象后该对象的原型也不能被修改.freeze() 返回和传入的参数相同的对象 用法 const objectExample = { prop1: 20, prop2: "羊先生" }; // 默认情况下,我们可以根据需

  • 详解如何在Java中调用Python程序

    Java中调用Python程序 1.新建一个Maven工程,导入如下依赖 <dependency> <groupId>org.python</groupId> <artifactId>jython-standalone</artifactId> <version>2.7.0</version> </dependency> 2.在java中直接执行python代码片段 import org.python.util

  • 详解如何在Java中实现堆排序算法

    目录 算法描述 实现代码 测试代码 算法描述 堆排序算法的描述如下: 将待排序的数组调整为最大堆,此时未排序的长度 N 为数组的长度,调整的过程就是倒序将数组的前 N/2 个元素下沉的过程,每次下沉都会将较大的元素带到上面,最终将数组变为最大堆: 弹出最大堆的堆顶元素并将其移动到数组的最后面,将原本最后面的元素放到堆顶,然后将未排序的长度 N - 1,调整数组的前 N 个元素为最大堆: 重复步骤 2 直到未排序的长度为 0. 实现代码 package com.zhiyiyo.collection

  • 详解如何在SpringBoot中自定义参数解析器

    目录 前言 1.自定义参数解析器 2.PrincipalMethodArgumentResolver 3.RequestParamMapMethodArgumentResolver 4.小结 前言 在一个 Web 请求中,参数我们无非就是放在地址栏或者请求体中,个别请求可能放在请求头中. 放在地址栏中,我们可以通过如下方式获取参数: String javaboy = request.getParameter("name "); 放在请求体中,如果是 key/value 形式,我们可以通

  • 详解如何在Vue中动态添加类名

    目录 静态和动态类 有条件的类名 使用数组语法 使用对象语法 与自定义组件一起使用 快速生成类名 使用计算属性来简化类 能够向组件添加动态类名是非常强大的功能.它使我们可以更轻松地编写自定义主题,根据组件的状态添加类,还可以编写依赖于样式的组件的不同变体. 添加动态类名与在组件中添加 prop :class="classname"一样简单.无论classname的计算结果是什么,都将是添加到组件中的类名. 当然,对于Vue中的动态类,我们可以做的还有很多.在本文中,我们将讨论很多内容:

随机推荐