华为HarmonyOS帮助应用实现在线认证服务 -- 2 FIDO免密身份认证
场景介绍
- 开通FIDO免密身份认证功能,使用用户已有的生物特征开通FIDO免密身份认证能力。
- 使用FIDO免密身份认证功能,使用用户已开通的生物特征进行FIDO免密身份认证。
- 关闭FIDO免密身份认证功能,使用用户已开通的生物特征注销FIDO免密身份认证能力。
基本概念
在开发FIDO免密身份认证功能前,开发者应了解以下基本概念:
- FIDO协议
FIDO(Fast Identity Online)是一套身份认证框架协议,它由FIDO联盟推出并持续维护。FIDO规范定义了一套在线身份认证的技术架构。
- UAF身份认证框架
UAF(Universal Authentication Framework)意为通用身份认证框架,目的是通过生物识别(如指纹识别)和加密技术方式,为用户提供无密码的身份认证体验。
约束与限制
需满足以下条件,才能使用该功能。
- 移动端设备需要支持生物特征(指纹/3D人脸)。
- FIDO服务需要联网,以便提供完整的在线身份校验服务。应用在调用本服务API前,需将FIDO服务联网行为向用户明示,并且取得用户同意。
接口说明
业务进行FIDO免密身份认证功能的开通、使用和关闭。
接口名 | 描述 |
---|---|
discover(context: common.Context): Promise<DiscoveryData> | 发现设备的认证能力,返回当前设备软件支持的认证器数据 |
checkPolicy(context: common.Context, uafRequest: UAFMessage): Promise<void> | 检测用户策略的开启状态 |
processUAFOperation(context: common.Context, uafRequest: UAFMessage, channelBindings?: ChannelBinding): Promise<UAFMessage> | 用户UAF操作接口,处理UAF协议消息 |
notifyUAFResult(context: common.Context, uafResponse: UAFMessage): Promise<void> | 开通结果通知接口 |
开发步骤
- 需要业务方自行根据FIDO标准协议部署FIDO服务器。
- 导入相关模块。
- import { fido } from '@kit.OnlineAuthenticationKit';
- import { BusinessError } from '@ohos.base';
- 开通FIDO免密身份认证。
- 初始化认证器信息。
- // 使用this.uiContext需要获取页面UIAbility的Context,一个页面获取一次即可
- // 方法:uiContext:common.UIAbilityContext = getContext(this) as common.UIAbilityContext;
- try {
- // 调用discover方法初始化认证器信息
- let discoverData = await fido.discover(this.uiContext);
- } catch (error) {
- const err: BusinessError = error as BusinessError;
- console.error(`Failed to call discover. Code is ${err.code}, message is ${err.message}`);
- // 业务根据错误码判断异常类型,进行相应处理
- }
- 访问FIDO服务端,获取策略检查报文,检查用户开通状态。
- // uafMessage为FIDO服务端获取的策略检查报文
- let uafAuthMessage: fido.UAFMessage = {
- uafProtocolMessage: uafMessage, // 从服务端获取的检查策略报文
- additionalData: "" // 附加信息(可选)
- };
- let isRegistered: boolean = true;
- try {
- // 检查是否已经开启FIDO认证
- await fido.checkPolicy(this.uiContext, uafAuthMessage);
- } catch (error) {
- isRegistered = false;
- const err: BusinessError = error as BusinessError;
- console.error(`Failed to call checkPolicy. Code is ${err.code}, message is ${err.message}`);
- // 业务根据错误码判断状态,进行相应处理
- }
- if (isRegistered) {
- console.info("has registered, no need to register again.");
- // 已注册,业务根据需要执行后续流程
- }
- 访问FIDO服务端,获取注册报文,调用processUAFOperation接口进行FIDO注册。
- // regMessage为从FIDO服务端获取的注册报文
- let uafRegMessage: fido.UAFMessage = {
- uafProtocolMessage: regMessage, // 从服务端获取的注册报文
- additionalData: "" // 附加信息(可选)
- };
- // 传连接通道参数(可选)
- let channelBinding: fido.ChannelBinding = {};
- try {
- // 调用processUAFOperation接口进行FIDO注册
- let messageResp = await fido.processUAFOperation(this.uiContext, uafRegMessage, channelBinding);
- } catch (error) {
- const err: BusinessError = error as BusinessError;
- console.error(`Failed to call processUAFOperation. Code is ${err.code}, message is ${err.message}`);
- // 业务根据错误码判断异常类型,进行相应处理
- }
- 发送注册响应报文至FIDO服务端进行验证并获取注册结果报文。
- // notifyMessage为从FIDO服务端获取的注册结果报文
- let notifyMessage:string = "";
- let notifyUafMessage: fido.UAFMessage = {
- uafProtocolMessage: notifyMessage, // 从服务端获取的注册结果报文
- additionalData: "" // 附加信息(可选)
- };
- 调用notifyUAFResult进行注册结果通知。
- try {
- // 调用notifyUAFResult进行注册结果通知
- fido.notifyUAFResult(this.uiContext, notifyUafMessage).then(notify => {
- console.info("Succeeded in doing notifyUAFResult.");
- })
- } catch (error) {
- const err: BusinessError = error as BusinessError;
- console.error(`Failed to call notifyUAFResult. Code is ${err.code}, message is ${err.message}`);
- // 业务根据错误码判断异常类型,进行相应处理
- }
- 初始化认证器信息。
- 使用FIDO免密身份认证。
- 初始化认证器信息(如果已执行过初始化操作,则无需重复执行)。
- // 获取当前界面的context
- try {
- // 调用discover方法初始化认证器信息
- let discoverData = await fido.discover(this.uiContext);
- } catch (error) {
- const err: BusinessError = error as BusinessError;
- console.error(`Failed to call discover. Code is ${err.code}, message is ${err.message}`);
- // 业务根据错误码判断异常类型,进行相应处理
- }
- 访问FIDO服务端,获取策略检查报文,检查用户开启状态。
- // uafMessage为从FIDO服务器获取的策略检查报文
- let uafAuthMessage: fido.UAFMessage = {
- uafProtocolMessage: uafMessage, // 从服务端获取的检查策略报文
- additionalData: "" // 附加信息(可选)
- };
- let isRegistered: boolean = true;
- try {
- // 检查是否已经开启FIDO认证
- await fido.checkPolicy(this.uiContext, uafAuthMessage);
- } catch (error) {
- isRegistered = false;
- const err: BusinessError = error as BusinessError;
- console.error(`Failed to call checkPolicy. Code is ${err.code}, message is ${err.message}`);
- // 业务根据错误码判断状态,进行相应处理
- }
- if (isRegistered) {
- console.info("has registered, no need to register again.");
- // 已注册,业务根据需要执行后续流程
- }
- 访问FIDO服务端,获取认证报文,调用processUAFOperation接口进行FIDO认证。
- // regMessage为从FIDO服务器获取的认证报文
- let uafRegMessage: fido.UAFMessage = {
- uafProtocolMessage: regMessage, // 从服务端获取的认证报文
- additionalData: "" // 附加信息(可选)
- };
- // 传连接通道参数(可选)
- let channelBinding: fido.ChannelBinding = {};
- try {
- // 调用processUAFOperation接口进行FIDO认证
- let messageResp = await fido.processUAFOperation(this.uiContext, uafRegMessage, channelBinding);
- } catch (error) {
- const err: BusinessError = error as BusinessError;
- console.error(`Failed to call processUAFOperation. Code is ${err.code}, message is ${err.message}`);
- // 业务根据错误码判断异常类型,进行相应处理
- }
- //发送认证响应报文至FIDO服务端进行验证并返回认证结果
- 初始化认证器信息(如果已执行过初始化操作,则无需重复执行)。
- 关闭FIDO免密身份认证。
- 初始化认证器信息(如果已执行过初始化操作,则无需重复执行)。
- try {
- // 调用discover方法初始化认证器信息
- let discoverData = await fido.discover(this.uiContext);
- } catch (error) {
- const err: BusinessError = error as BusinessError;
- console.error(`Failed to call discover. Code is ${err.code}, message is ${err.message}`);
- // 业务根据错误码判断异常类型,进行相应处理
- }
- 访问FIDO服务端,获取注销报文,调用processUAFOperation接口进行FIDO注销。
- // deregMessage为从FIDO服务器获取的注销报文
- let uafRegMessage: fido.UAFMessage = {
- uafProtocolMessage: deregMessage, // 从服务端获取的注销报文
- additionalData: "" // 附加信息(可选)
- };
- // 传连接通道参数(可选)
- let channelBinding: fido.ChannelBinding = {};
- try {
- // 调用processUAFOperation接口进行FIDO注销
- let messageResp = await fido.processUAFOperation(this.uiContext, uafRegMessage, channelBinding);
- } catch (error) {
- const err: BusinessError = error as BusinessError;
- console.error(`Failed to call processUAFOperation. Code is ${err.code}, message is ${err.message}`);
- // 业务根据错误码判断异常类型,进行相应处理
- }
- //发送认证响应报文至FIDO服务端进行验证并返回认证结果
- 初始化认证器信息(如果已执行过初始化操作,则无需重复执行)。