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

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

最近发现华为AGC认证服务支持Flutter框架了,期待这个平台的支持已经好久了,因此火烧眉毛接入了,关联了本身的邮箱等帐号。java

集成步骤

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

在这里插入图片描述
将压缩包解压到任意文件夹,例如D:\Flutterandroid

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

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

在这里插入图片描述

  1. 开通服务&建立工程

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

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

在这里插入图片描述

c) 在Android Studio中新建Flutter工程async

在这里插入图片描述

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

在这里插入图片描述

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

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

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

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

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

在这里插入图片描述

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

在这里插入图片描述

  1. 集成SDK
    在Flutter项目的pubspec.yaml文件中添加依赖:
dependencies:
    flutter:
    sdk: flutter
# Add the following line:
    agconnect_auth: ^1.1.0

而后点击Pub get进行同步

在这里插入图片描述

  1. 接入功能
  2. 匿名账号登陆
    匿名账号只须要调用signInAnonymously接口进行登陆
_signIn() async {
  AGCAuth.instance.signInAnonymously().then((value) {
    setState(() {
      _log =
          'signInAnonymously = ${value.user.uid} , ${value.user.providerId}';
    });
  });
}

经过value,咱们能够获取到用户信息,例如这里咱们获取到了user的id。

  1. 手机号&邮箱认证

手机号邮箱帐号认证首先须要发送验证码,

手机号请求验证码,即调用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}';
     });
   });
 }
  1. 自有帐号
    自有帐号建立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}';
     });
   });
 }
  1. 打包
    与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

相关文章
相关标签/搜索