接入文档
FaceID高级版
H5接入
API调用
获取Token
获取Token
# 1、接口地址
POST https://api.megvii.com/faceid/lite/get_token
注意:在生产环境中,请使用HTTPS的通信方式。HTTP方式的通信属于不安全链路,存在安全风险,请勿在生产环境中使用。在生产环境中使用HTTP方式的,将无法得到服务可靠性保障。
说明:此接口提供FaceID H5验证服务,通过此接口客户可以获得一个token(token唯一且只能使用一次)。接口同时还能帮助完成人脸比对,并在完成验证后自动将人脸比对结果返回,方便集成开发。
# 2、入参说明
# 2.1、基础参数
必选/可选 | 参数 | 类型 | 参数说明 | |||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
必选 | api_key | String | 调用此API的api_key | |||||||||||||||||||||
必选 | api_secret | String | 调用此API的api_key的secret | |||||||||||||||||||||
必选 | return_url | String | 用户完成或取消验证后网页跳转的目标URL(回调方法为Post) | |||||||||||||||||||||
必选 | notify_url | String | 用户完成验证、取消验证、或验证超时后,由FaceID服务器请求客户服务器的URL(推荐为HTTPS页面,如果为HTTP则用户需要通过签名自行校验数据可信性,回调方法为Post) 注:出于安全性考虑,FaceID验证服务服务对服务器端回调端口有白名单要求,支持的端口有:443,5000,16003,8883,8028 | |||||||||||||||||||||
必选 | biz_no | String | 客户业务流水号,该号必须唯一。并会在notify和return时原封不动的返回给您的服务器,以帮助您确认每一笔业务的归属。此字段不超过128字节 | |||||||||||||||||||||
必选 | procedure_type | String |
刷脸活体验证流程的选择。目前仅取以下值:
|
|||||||||||||||||||||
可选 | procedure_priority | String |
本参数可选,通过本参数配置不支持webrtc技术的降级方式
|
|||||||||||||||||||||
必选 | comparison_type | String |
设定本次服务的类型,目前支持的比对类型为“人脸核身”(取值“1”)或“人脸比对”(取值“0”)。传递其他值调用将识别,返回错误码400(BAD_ARGUMENTS)
|
|||||||||||||||||||||
二选一:人脸核身时(comparison_type = 1) | 必选 | idcard_mode | String |
传递参数“0”,“1”,“2”,“3”或“4”,表示获取用户身份证信息的方法。传递其他值调用将识别,返回错误码400(BAD_ARGUMENTS)
|
||||||||||||||||||||
可选 | idcard_uneditable_field | String | 选择用户不可编辑的字段。当选择拍摄身份证来获取上面的文字信息时,会由于OCR算法的问题导致文字识别不准确(如:生僻字、形近字),通过该参数可以限制用户对识别得到的结果进行编辑。(如:身份证号的识别都是准确的,可以限制用户不能编辑此字段) 目前可以选为不可修改的字段有 姓名(idcard_name),身份证号(idcard_number),身份证有效期(idcard_valid_date),签发机关(idcard_issued_by)。传递参数时用逗号隔开,可以同时设置多个参数。例子:idcard_uneditable_field = idcard_number,idcard_valid_date 表示身份证号和过期时间都不可编辑,如果尝试编辑则会提示需要重新拍摄。传入其他值或格式不对,本次调用将失败,返回错误码400(BAD_ARGUMENTS) 本参数默认值为空,表示所有字段都可以编辑 请注意,如果您设置了scene_id参数、或者在控制台里设置了默认的场景,它对应的场景配置里将覆盖您此处的设定 | |||||||||||||||||||||
条件必选 | idcard_name | String | idcard_name,需要人脸核身对象的姓名,使用UTF-8编码 idcard_number, 需要人脸核身对象的身份证号,也就是一个18位长度的字符串 idcard_mode = 0时,这两个参数必须传;在其他情况下可以不传,即使传递了也不会使用 | |||||||||||||||||||||
条件必选 | idcard_number | String | ||||||||||||||||||||||
可选 | image_ref[x] | File | 多张由您自己提供的参照人脸照片。x表示此参数可重复多次,其中1 <= x <= 2,即表示可以传最多二张参照人脸照片(参数分别为image_ref1, image_ref2) 如果在image_ref1、image_ref2中的任一张图片里没有找到人脸,将返回错误码400(NO_FACE_FOUND) 如果这些图片中任一张中有多张脸,将返回错误码400(MULTIPLE_FACES) | |||||||||||||||||||||
二选一:人脸比对时(comparison_type = 0) | 必选 | uuid | String | 如果用户不使用参考数据进行比对,则上传此字段,用于标志本次识别对应的用户的唯一ID,要求不长于512字节。建议您对来自同一用户的比对请求使用同样的ID,这非常有利于您反查验证结果以及获得更好的数据报表体验 | ||||||||||||||||||||
必选 | image_ref[x] | File | 多张由您自己提供的参照人脸照片。x表示此参数可重复多次,其中1 <= x <= 2,即表示可以传最多二张参照人脸照片(参数分别为image_ref1, image_ref2) 如果在image_ref1、image_ref2中的任一张图片里没有找到人脸,将返回错误码400(NO_FACE_FOUND) 如果这些图片中任一张中有多张脸,将返回错误码400(MULTIPLE_FACES) | |||||||||||||||||||||
可选 | will_type | String |
选择意愿认证模式
|
|||||||||||||||||||||
可选 | will_config_mode | String |
选择配置意愿活体相关参数的方式
|
|||||||||||||||||||||
条件必选 | scene_id | String |
当will_config_mode=0时,必需传此参数 在控制台配置的对应使用场景的scene_id,用以自定义验证流程中的视觉元素和意愿活体相关配置; 如果传入了不存在的scene_id,调用将失败且返回错误码400(BAD_ARGUMENTS) |
|||||||||||||||||||||
条件必选 | will_config | String |
当will_config_mode=1时,必需传此参数。意愿活体系统播报问题和用户回答文本配置,最多支持配置5组问答。
点头模式示例: [{"question":"您好,为确保您本人操作,此次签约全程录音录像。请问您本次业务是本人自愿办理吗?请'点头'确认"}] |
|||||||||||||||||||||
可选 | answer_timeout | Int | 回答超时时间,单位为秒,默认为3s,可配置 3s、5s、8s | |||||||||||||||||||||
可选 | speed | String |
用于设置意愿活体播报问题语速
|
|||||||||||||||||||||
可选 | is_return_will_file | Int |
选择是否返回本次意愿认证所有意愿问答相关信息及音频
|
|||||||||||||||||||||
可选 | force_compare | String |
表示意愿认证失败后,是否依然进行比对
|
# 2.2、高级参数
可选 | 参数 | 类型 | 参数说明 | |||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
可选 | encryption_type | String |
是否开启传输数据加密,详细说明见:加密说明
|
|||||||||||||||||||||
可选 | biz_extra_data | String | 在调用notify_url和return_url时会返回的额外数据,用户可以用此接口来传递一些额外信息,以帮助您调试和信息传递。此字段不超过4096字节 | |||||||||||||||||||||
可选 | web_title | String |
验证网页展示用的标题文字。此字段不超过32字节,但考虑到显示效果,建议控制在10个中文字符以内
此参数默认为空,此时系统将采用默认的标题 请注意,如果您设置了scene_id参数、或者在控制台里设置了默认的场景,它对应的场景配置将覆盖您此处的设定 |
|||||||||||||||||||||
可选 | multi_oriented_detection | String |
决定对于image_ref[x]参数对应的图片,当检测不出人脸时,是否旋转90度、180度、270度后再检测人脸。本参数取值只能是 “1” 或 "0" (缺省值为“0”):
|
|||||||||||||||||||||
可选 | get_fail_reason | String |
决定在WEBRTC_UNSUPPORTED时,是否返回失败原因(缺省值为“0”)
|
|||||||||||||||||||||
可选 | face_occlusion_detection | String |
用于设置是否开启人脸遮挡检测
|
|||||||||||||||||||||
可选 | eye_close_detection | String |
用于设置是否开启闭眼检测
|
|||||||||||||||||||||
可选 | action_http_method | String | 回跳到return_url的方式 | |||||||||||||||||||||
可选 | redirect_type | String |
页面跳转模式(当redirect_type =1且action_http_method=GET时,支持点击浏览器或者操作系统的返回键可返回到进入lite之前的页面)
|
# 3、返回结果
字段 | 类型 | 说明 |
---|---|---|
request_id | String | 用于区分每一次请求的唯一的字符串,此字符串可以用于后续数据反查,此字段必定返回 |
time_used | Int | 整个请求所花费的时间,单位为毫秒,此字段必定返回 |
token | String | 一个字符串,可用于DoVerification接口,调用DoVerification时传入此参数,即可按照上述配置进行活体检测(注:每个token只能被使用一次) |
biz_id | String | 业务流串号,可以用于反查比对结果 |
expired_time | Int | 一个时间戳,表示token的有效期 |
error_message | String | 当请求失败时才会返回此字符串,具体返回内容见后续错误信息章节,否则此字段不存在 |
成功示例
{
"time_used": 5,
"token": "34fb21937e47ae719f11cbc719615687",
"biz_id": "1462259748,52b13fb5-8dfb-4537-a62b-a641d5e929f1",
"request_id": "1462257147,3149525e-2c24-4862-8e9f-92040595f0a4",
"expired_time": 1462257765
}
失败示例
{
"error_message": "BAD_ARGUMENTS: return_url",
"request_id": "1461740007,71eeb124-08f0-47b3-8fc8-ac048cfa1372",
"time_used": 4
}
# 4、错误码列表
GetToken 特有的 ERROR_MESSAGE
HTTP状态代码 | 错误字段名称 | 值 | 说明 |
---|---|---|---|
400 | error_message | IMAGE_ERROR_UNSUPPORTED_FORMAT:<param> | 参数<param>对应的图像无法正确解析,有可能不是一个图像文件、或有数据破损。<param>为 image_ref1、 image_ref2中的一个。请注意:<param>只会有一项,即第一个满足条件的名称 |
400 | error_message | NO_FACE_FOUND | 表示上传的 image_ref[x]的图像中,没有检测到人脸 |
400 | error_message | MULTIPLE_FACES | 表示上传的 image_ref[x]的图像中,检测到了多张人脸 |
400 | error_message | INVALID_NAME_FORMAT | 人脸核身时,idcard_name参数字符数过多(多于32字符)、或者使用错误的编码(姓名要求以UTF-8编码) |
400 | error_message | INVALID_IDCARD_NUMBER | 人脸核身时,idcard_number参数不是正确的身份证号码格式。身份证号码必定为18位数字,且最后一位可以是X(大小写均可) |
400 | error_message | KEY_NOT_FOUND | encryption_type开启加密,但未配置加密公钥和解密私钥 |
通用的ERROR_MESSAGE
HTTP状态代码 | 错误字段名称 | 值 | 说明 |
---|---|---|---|
403 | error | AUTHENTICATION_ERROR | api_key 和 api_secret不匹配 |
403 | error | AUTHORIZATION_ERROR:<reason> | api_key被停用、调用次数超限、没有调用此API的权限,或者没有以当前方式调用此API的权限。目前的<reason>有:"Denied." :(没有权限调用当前API)"No data source permission." : (表示没有调用第三方联网核查) NO_WILL_PERMISSION:没有意愿核身的权限,但是本次请求依然尝试调用了 |
403 | error_message | CONCURRENCY_LIMIT_EXCEEDED | 并发数超过限制 |
400 | error_message | MISSING_ARGUMENTS:<key> | 缺少某个必选参数 |
400 | error_message | BAD_ARGUMENTS:<key> | 某个参数解析出错(比如必须是数字,但是输入的是非数字字符串; 或者长度过长) |
404 | error | API_NOT_FOUND | 所调用的API不存在 |
500 | error_message | INTERNAL_ERROR | 服务器内部错误,当此类错误发生时请再次请求,如果持续出现此类错误,请及时联系 FaceID 客服或商务 |
该文档未解决您的疑问?查看常见问题