鸿蒙应用元服务开发-Account Kit配置登录权限

一、场景介绍

华为账号登录是基于OAuth 2.0协议标准和OpenID Connect协议标准构建的OAuth2.0 授权登录系统,元服务可以方便地获取华为账号用户的身份标识,快速建立元服务内的用户体系。

用户打开元服务时,不需要用户点击登录/注册按钮,即可获取用户的身份标识UnionID/OpenID,完成静默登录。静默登录详细接入体验可参考Account Kit提供的SampleCode示例工程。

如果您需要将用户与已注册账号关联时,为用户同步历史数据资产,可以向用户申请获取手机号。

二、基础概念

华为账号用户身份标识包含UnionID和OpenID,具体格式要求请参考OpenID和UnionID的格式说明,两者的定义与使用场景:

说明

在开发元服务时,您需要考虑同一用户在非元服务和元服务的用户数据是否互通。如果您之前使用OpenID来关联用户数据,我们建议将用户数据关系切换成UnionID,以确保您的用户使用元服务后可以继承老版本的用户数据。

三、业务流程

流程说明:

1、用户打开元服务,元服务业务方调用登录API传入forceLogin = false等参数调用登录API。

2、如华为账号未登录,元服务会获取到1001502001 用户未登录华为账号错误码,再根据需要自行处理。

3、如华为账号已登录,且API调用成功,元服务能获取到UnionID、Authorization Code等登录结果。

4、元服务通过用户身份标识UnionID判断用户已登录后,服务端进行安全认证后用户即可完成静默登录。

四、接口说明

静默登录关键接口如下表所示,具体API说明详见API参考。

五、开发前提

在进行代码开发前,请先确认您已完成配置Client ID工作。该场景无需申请scope权限。

六、客户端开发

导入authentication模块及相关公共模块。

复制代码
import { authentication } from '@kit.AccountKit';
import { util } from '@kit.ArkTS';
import { hilog } from '@kit.PerformanceAnalysisKit';
import { BusinessError } from '@kit.BasicServicesKit';

创建登录请求并设置参数

复制代码
// 创建登录请求,并设置参数
const loginRequest = new authentication.HuaweiIDProvider().createLoginWithHuaweiIDRequest();
// false表示当用户未登录华为账号时,不会拉起华为账号登录界面;直接返回1001502001错误码。
loginRequest.forceLogin = false;
// 用于防跨站点请求伪造。
loginRequest.state = util.generateRandomUUID();

调用AuthenticationController对象的executeRequest方法执行登录请求,并处理登录结果,获取到UnionID、OpenID、Authorization Code及ID Token。之后将Authorization Code传给元服务服务器处理,可参考客户端与服务端交互开发的开发步骤a和b。元服务可以通过公开的网址获取到华为账号服务器发布的公钥,对签名和ID Token中的必要信息进行验证,以证明其没有被篡改过。解析ID Token可参考ID Token解析与验证。

复制代码
// 执行登录请求
try {
  const controller = new authentication.AuthenticationController();
  controller.executeRequest(loginRequest).then((response: authentication.LoginWithHuaweiIDResponse) => {
      const loginWithHuaweiIDResponse = response as authentication.LoginWithHuaweiIDResponse;
      const state = loginWithHuaweiIDResponse.state;
      if (state && loginRequest.state !== state) {
        hilog.error(0x0000, 'testTag', `Failed to login. The state is different, response state: ${state}`);
        return;
      }
      hilog.info(0x0000, 'testTag', 'Succeeded in logging in.');
      const loginWithHuaweiIDCredential = loginWithHuaweiIDResponse.data!;
      const code = loginWithHuaweiIDCredential.authorizationCode;
      const idToken = loginWithHuaweiIDCredential.idToken;
      const openID = loginWithHuaweiIDCredential.openID;
      const unionID = loginWithHuaweiIDCredential.unionID;
      // 开发者处理code, idToken, openID, unionID
  }).catch((error: BusinessError) => {
    this.dealAllError(error);
  })
} catch (error) {
  this.dealAllError(error);
}
// 错误处理
dealAllError(error: BusinessError): void {
  hilog.error(0x0000, 'testTag', 'Failed to login, errorCode=%{public}d, errorMsg=%{public}s', error.code,
    error.message);
}

七、服务端开发

1.元服务服务器使用Client ID、Client Secret、Authorization Code调用获取用户级凭证的接口向华为账号服务器请求获取Access Token、Refresh Token。

2.使用Access Token调用解析凭证接口获取用户的UnionID。

(1)Access Token过期处理

由于Access Token的有效期仅为60分钟,当Access Token失效或者即将失效时(可通过REST API错误码判断),可以使用Refresh Token(有效期180天)通过刷新凭证向华为账号服务器请求获取新的Access Token。

说明

当Access Token失效时,若元服务不使用Refresh Token向华为账号服务器请求获取新的Access Token,账号的授权信息将会失效,导致使用Access Token的功能都会失败。

当Access Token非正常失效(如修改密码、退出账号、删除设备)时,元服务可重新登录授权获取Authorization Code,向华为账号服务器请求获取新的Access Token。

(2)Refresh Token过期处理

由于Refresh Token的有效期为180天,当Refresh Token失效后(可通过REST API错误码判断),元服务服务器需要通知客户端,重新调用授权接口,请求用户重新授权。

3.元服务在自己的用户体系通过查询获取的UnionID判断该用户是否已关联。如已关联,则完成用户登录;如未关联,则创建新用户,绑定UnionID,完成用户登录。

本文主要引用参考HarmonyOS官方网站

相关推荐
一起养小猫1 分钟前
Flutter for OpenHarmony 实战:数据持久化方案深度解析
网络·jvm·数据库·flutter·游戏·harmonyos
小天源18 分钟前
XShell一台控制多台操作详情
linux·运维·服务器
xu_yule19 分钟前
网络和Linux网络-13(高级IO+多路转接)五种IO模型+select编程
linux·网络·c++·select·i/o
安科士andxe41 分钟前
纤云科技 EPON OLT PX20 + 光模块:高兼容低功耗的光纤接入优选方案
网络·科技
夜流冰1 小时前
编程参考 - Linux kernel代码查看
linux·运维·服务器
xu_yule1 小时前
网络和Linux网络-14(IO多路转接)poll和epoll编程-服务器
linux·运维·服务器·epoll·poll
timi先生1 小时前
全新的linux如何进行远程xshell操作?
linux·运维·服务器
车载testing1 小时前
SOME/IP 协议中发送 RR 报文的实践指南
网络·tcp/ip·安全
程序员一点1 小时前
第4章:Linux 文件系统结构与路径管理
linux·运维·服务器
百炼成神 LV@菜哥1 小时前
Kylin Linux V10 aarch64安装DBeaver
java·linux·服务器·kylin