# 切换自定义认证
统一用户认证框架提供了切换业务自定义认证机制。如果设备厂商自定义了其他认证能力对接到统一用户认证框架,应用开发者可以切换到自定义认证的方式。
例如,在支付场景中,如果厂商自定义了支付密码认证的方式,当调用系统人脸或指纹认证失败后,用户可以选择切换支付密码认证。
支付密码认证不属于系统认证能力,因此业务在发起认证时需要传入导航键的显式信息,如“使用支付密码”,这样用户看到的认证界面便会包含一个“使用支付密码”的按钮。
当用户点击该按钮,发起认证的业务应用便会收到统一用户认证框架返回的一个特殊认证结果,提示业务系统认证结束,需要拉起业务自定义的认证界面。这样,用户在点击“使用支付密码”按钮后,便会看到系统认证控件消失,显示出业务自定义的支付密码认证界面。

如图,框选区域为WidgetParam.navigationButtonText字段显示,开发者可配置此字段,引导用户从生物认证切换到应用自定义业务密码认证。
> **说明:**
> 锁屏密码认证与业务自定义认证只能二选一,不能同时存在。
| 认证类型 | 支持切换业务自定义认证方式。
(√表示支持,x表示不支持。) |
| -------- | -------- |
| 锁屏密码认证 | × |
| 人脸认证 | √ |
| 指纹认证 | √ |
| 人脸+指纹18+ | √ |
| 人脸+锁屏密码认证 | × |
| 指纹+锁屏密码认证 | × |
| 人脸+指纹+锁屏密码认证 | × |
## 开发示例
针对需要切换自定义认证方式的场景,发起认证请求的方式请参考[发起认证](start-authentication.md),但在传入的widgetParam需包含字段navigationButtonText。
当前示例仅展示如何配置界面、选择切换到自定义认证界面,具体拉起的页面及对应页面的实现,请开发者自行实现,代码插入位置可参考注释提示。
```ts
import { BusinessError } from '@kit.BasicServicesKit';
import { cryptoFramework } from '@kit.CryptoArchitectureKit';
import { userAuth } from '@kit.UserAuthenticationKit';
try {
const rand = cryptoFramework.createRandom();
const len: number = 16;
const randData: Uint8Array = rand?.generateRandomSync(len)?.data;
const authParam: userAuth.AuthParam = {
challenge: randData,
authType: [userAuth.UserAuthType.FACE],
authTrustLevel: userAuth.AuthTrustLevel.ATL3,
};
// 配置认证界面需设置navigationButtonText。
const widgetParam: userAuth.WidgetParam = {
title: '请验证身份',
navigationButtonText: '使用密码',
};
// 获取认证对象。
const userAuthInstance = userAuth.getUserAuthInstance(authParam, widgetParam);
console.info('get userAuth instance success');
// 订阅认证结果。
userAuthInstance.on('result', {
onResult(result) {
// 若收到ResultCode值为12500000,代表操作成功。
console.info(`userAuthInstance callback result = ${JSON.stringify(result)}`);
// 若收到ResultCode值为12500011,说明用户点击了导航按钮想切换自定义认证方式。
if (result.result == 12500011) {
//请开发者自行完成拉起自定义认证界面的实现。
}
}
});
console.info('auth on success');
userAuthInstance.start();
console.info('auth start success');
} catch (error) {
const err: BusinessError = error as BusinessError;
console.error(`auth catch error. Code is ${err?.code}, message is ${err?.message}`);
}
```