Fingerprint模块
的地址:https://ext.dcloud.net.cn/plugin?id=358效果图
使用指纹识别必须具备以下条件:
1、当前设备是否支持指纹识别
2、当前设备是否设置密码锁屏
3、当前设备是否已经录入指纹。(Android平台6.0及以上系统支持,只识别标准Android的指纹API,仅适配Google官方指纹识别的标准接口的设备)
以上条件都要满足才可以使用识别功能,即与手机中已录入的指纹进行比对检测,即只有与手机中录入任意指纹比对成功,才可以进入成功回调。
下面是使用方法:
1、获取权限:在manifest.json文件中配置
2、使用plus.fingerprint.isSupport()方法判断当前设备是否支持指纹识别
if (!plus.fingerprint.isSupport()) { plus.nativeUI.toast('此设备不支持指纹识别'); console.log('此设备不支持指纹识别') }3、使用plus.fingerprint.isKeyguardSecure()判断是否开启密码锁屏
if (!plus.fingerprint.isKeyguardSecure()) { plus.nativeUI.toast('此设备未设置密码锁屏'); console.log('此设备未设置密码锁屏') }4、使用plus.fingerprint.isEnrolledFingerprints()判断是否录入指纹
if (!plus.fingerprint.isEnrolledFingerprints()) { plus.nativeUI.toast('此设备未录入指纹'); console.log('此设备未录入指纹') }下面是对上面代码进行的封装:
fingerprint(){ plus.fingerprint.authenticate(function() { //成功回调 console.log('匹配成功'); }, function(e) { switch (e.code) { case e.AUTHENTICATE_MISMATCH: plus.nativeUI.toast('指纹匹配失败,请重新输入'); break; case e.AUTHENTICATE_OVERLIMIT: plus.nativeUI.closeWaiting(); //兼容Android平台关闭等待框 plus.nativeUI.toast('指纹识别失败次数超出限制,请使用其它方式进行认证'); break; case e.CANCEL: plus.nativeUI.toast('已取消识别'); break; default: plus.nativeUI.closeWaiting(); //兼容Android平台关闭等待框 plus.nativeUI.toast('指纹识别失败,请重试'); break; } }); }注:从HBuilderX 2.3.8起,uni-app已经统一了生物认证的实现,并且支持iOS App端的faceID,详见:https://uniapp.dcloud.io/api/system/authentication