现在人脸识别功能,只对特定主主体类目进行开放,具体主体类目参考:
人脸识别开放主题类目 | 微信社区 (qom)
申请人脸识别功能的详细过程,可查看 微信人脸核身申请过程 | 微信开放社区 (qq.com)
前端操作:
/* 发送请求将数据发送给后台 */
requestIdentify() {
const that = this;
const data = {
name: that.data.name, //用户姓名
id_card_number: that.data.card //用户的身份证号
}
wx.showLoading({
title: '加载中',
})
wx.request({
url: '后台接口地址',
data: data,
success(res) {
if (res.data.ec == 200) {
//这里验证成功进行下一步验证操作
}else{
//如果没有验证成功,弹出框提示用户错误信息
app.errorTip(that, res.data.em, 2000);
}
},
complete() {
wx.hideLoading()
console.log('调用完成')
}
})
}
后端操作(没有具体代码,重点跑逻辑),后端拿到这个身份信息需要调用微信提供的 api,进行身份验证,
1、请求URL
https://api.weixin.qq.com/cityservice/face/identify/getuseridkey?access_token={access_token}
access_token 表示登录的状态 token
2、请求方式
POST
3、请求数据格式
//Json 数据格式
{
"name" : “张三”,
"id_card_number" : "452122xxxxxxx43215"
}
4、返回数据
参数 | 类 型 | 说明 |
---|---|---|
errcode | int | 错误码 |
errmsg | string | 错误信息 |
user_id_key | string | 用于后台交互表示用户姓名、身份证的凭证 |
expires_in | uint32 | user_id_key 有效期,过期需重新获取 |
通过验证之后,以上返回的数据也是给我们前端返回的数据,
/* 人脸识别 */
faceRecogniza(user_id_key) {
const that = this
/* 检查设备是否支持人脸识别 */
wx.checkIsSupportFacialRecognition({
success(res) {
/* 开始进行人脸识别 */
wx.startFacialRecognitionVerify({
userIdKey: that.data.userIdKey,
success(res) {
/* 第一次验证成功 */
// 拿到用户凭据
if (res.errCode == 0) {
/* 获取加密 key 再次验证 */
that.requestVerify(res.verifyResult)
}
},
fail(res) {
if (res.errCode == 90100) {
app.errorTip(that, '用户取消授权', 2000)
}
},
complete() {
console.log(111111)
}
})
},
fail(res) {
app.errorTip(that, '该设备暂不支持人脸识别', 2000)
},
complete() {
console.log('调用完毕')
}
})
}
我们调用完 js Api 接口之后,仍然需要拿到凭据 verifyResult,进行最后一次验证,保证信息的准确性,具体代码:
前端:
//最后一次验证
requestVerify(verifyResult) {
const that = this;
const data = {
verify_result: verifyResult,
}
wx.request({
url: '后台接口',
data: data,
success(res) {
/* 再次检验成功 */
//执行接下来的业务逻辑
},
fail(res) {
console.log(res)
},
complete() {
}
})
}
后端:需要再次拿到我们前端传递的 verifyResult,再次调用验证身份信息,
1、请求URL
https://api.weixin.qq.com/cityservice/face/identify/getinfo?access_token={access_token}
2、请求方式
POST
3、请求格式
json
4.请求数据
参数 | 类型 | 是否必填 | 描述 |
---|---|---|---|
verify_result | String | 是 | jsapi返回的加密key(凭据) |
5.返回参数说明
注:errcode和identify_ret同时为0,代表本次认证成功。
参数 | 类型 | 描述 |
---|---|---|
errcode | int | 错误码, 0表示本次api调用成功 |
errmsg | string | 本次api调用的错误信息 |
identify_ret | int | 人脸核身最终认证结果 |
identify_time | uint32 | 认证时间 |
validate_data | string | 用户读的数字(如是读数字) |
openid | string | 用户openid |
user_id_key | string | 用于后台交互表示用户姓名、身份证的凭证 |
finish_time | uint32 | 认证结束时间 |
id_card_number_md5 | string | 身份证号的md5(最后一位X为大写) |
name_utf8_md5 | string | 姓名MD5 |
(1)点击同意,点击开始验证按钮
这里我们避免一个问题:在页面的onLoad方法中直接调用人脸识别接口最有可能导致这个问题,因为很可能 webview 还没加载完。于是,在onLoad方法中只赋值,在页面单独加个按钮,点击时触发人脸识别接口。
(2)调用接口,点击下一步
(3)开始验证
(4)提示验证结果
如果验证成功,可以进行下一步业务操作,如果验证失败,会提示错误信息,进行信息修改确认至此,人脸识别就完成了.