人脸比对加密版
人脸识别接口分为V2和V3两个版本,本文档为V3版本接口的说明文档,请确认您在百度云后台获得的是V3版本接口权限,再来阅读本文档。
辨别接口版本的方法是:在百度云后台进入【应用列表】,点击【应用名称】,在【API列表】中可以看到【请求地址】,若请求地址中带有【v3】标识,则您具有的是v3权限,可以阅读本文档;若请求地址中带有【v2】标识,则您具有的是v2权限,应该去阅读v2文档。 如果您对文档内容有任何疑问,可以通过以下几种方式联系我们:
人脸比对加密版
能力介绍
业务能力 接口能力
- 两张人脸图片相似度对比:比对两张图片中人脸的相似度,并返回相似度分值;
- 多种图片类型:支持生活照、证件照、身份证芯片照、带网纹照四种类型的人脸对比;
- 活体检测控制:基于图片中的破绽分析,判断其中的人脸是否为二次翻拍(举例:如用户A用手机拍摄了一张包含人脸的图片一,用户B翻拍了图片一得到了图片二,并用图片二伪造成用户A去进行识别操作,这种情况普遍发生在金融开户、实名认证等环节。);
- 质量检测控制:分析图片的中人脸的模糊度、角度、光照强度等特征,判断图片质量;
- 图片加密及风控:配合采集SDK4.1版本使用,对采集SDK输出的加密图片进行解密(加密传输可以有效避免第三方非法黑产绕过APP模拟请求攻击云端接口的行为);以及结合百度安全实验室大数据风控能力,对采集SDK的发起端设备进行风控识别,辨别是否为风险设备。
业务应用
用于比对多张图片中的人脸相似度并返回两两比对的得分,可用于判断两张脸是否是同一人的可能性大小。
典型应用场景:如人证合一验证,用户认证等,可与您现有的人脸库进行比对验证。
调用方式
请求URL数据格式
向API服务地址使用POST发送请求,必须在URL中带上参数access_token,可通过后台的API Key和Secret Key生成,具体方式请参考“Access Token获取”。
请求URL数据格式
向API服务地址使用POST发送请求,必须在URL中带上参数access_token,可通过后台的API Key和Secret Key生成,具体方式请参考“Access Token获取”。
示例代码
1#!/bin/bash
2curl -i -k 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=【百度云应用的AK】&client_secret=【百度云应用的SK】'1<?php
2function request_post($url = '', $param = '') {
3        if (empty($url) || empty($param)) {
4            return false;
5        }
6        
7        $postUrl = $url;
8        $curlPost = $param;
9        $curl = curl_init();//初始化curl
10        curl_setopt($curl, CURLOPT_URL,$postUrl);//抓取指定网页
11        curl_setopt($curl, CURLOPT_HEADER, 0);//设置header
12        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);//要求结果为字符串且输出到屏幕上
13        curl_setopt($curl, CURLOPT_POST, 1);//post提交方式
14        curl_setopt($curl, CURLOPT_POSTFIELDS, $curlPost);
15        $data = curl_exec($curl);//运行curl
16        curl_close($curl);
17        
18        return $data;
19    }
20
21    $url = 'https://aip.baidubce.com/oauth/2.0/token';
22    $post_data['grant_type']       = 'client_credentials';
23    $post_data['client_id']      = '你的 Api Key';
24    $post_data['client_secret'] = '你的 Secret Key';
25    $o = "";
26    foreach ( $post_data as $k => $v ) 
27    {
28        $o.= "$k=" . urlencode( $v ). "&" ;
29    }
30    $post_data = substr($o,0,-1);
31    
32    $res = request_post($url, $post_data);
33
34    var_dump($res);
35
36?>1package com.baidu.ai.aip.auth;
2
3import org.json.JSONObject;
4
5import java.io.BufferedReader;
6import java.io.InputStreamReader;
7import java.net.HttpURLConnection;
8import java.net.URL;
9import java.util.List;
10import java.util.Map;
11
12/**
13 * 获取token类
14 */
15public class AuthService {
16
17    /**
18     * 获取权限token
19     * @return 返回示例:
20     * {
21     * "access_token": "24.460da4889caad24cccdb1fea17221975.2592000.1491995545.282335-1234567",
22     * "expires_in": 2592000
23     * }
24     */
25    public static String getAuth() {
26        // 官网获取的 API Key 更新为你注册的
27        String clientId = "百度云应用的AK";
28        // 官网获取的 Secret Key 更新为你注册的
29        String clientSecret = "百度云应用的SK";
30        return getAuth(clientId, clientSecret);
31    }
32
33    /**
34     * 获取API访问token
35     * 该token有一定的有效期,需要自行管理,当失效时需重新获取.
36     * @param ak - 百度云官网获取的 API Key
37     * @param sk - 百度云官网获取的 Securet Key
38     * @return assess_token 示例:
39     * "24.460da4889caad24cccdb1fea17221975.2592000.1491995545.282335-1234567"
40     */
41    public static String getAuth(String ak, String sk) {
42        // 获取token地址
43        String authHost = "https://aip.baidubce.com/oauth/2.0/token?";
44        String getAccessTokenUrl = authHost
45                // 1. grant_type为固定参数
46                + "grant_type=client_credentials"
47                // 2. 官网获取的 API Key
48                + "&client_id=" + ak
49                // 3. 官网获取的 Secret Key
50                + "&client_secret=" + sk;
51        try {
52            URL realUrl = new URL(getAccessTokenUrl);
53            // 打开和URL之间的连接
54            HttpURLConnection connection = (HttpURLConnection) realUrl.openConnection();
55            connection.setRequestMethod("GET");
56            connection.connect();
57            // 获取所有响应头字段
58            Map<String, List<String>> map = connection.getHeaderFields();
59            // 遍历所有的响应头字段
60            for (String key : map.keySet()) {
61                System.err.println(key + "--->" + map.get(key));
62            }
63            // 定义 BufferedReader输入流来读取URL的响应
64            BufferedReader in = new BufferedReader(new InputStreamReader(connection.getInputStream()));
65            String result = "";
66            String line;
67            while ((line = in.readLine()) != null) {
68                result += line;
69            }
70            /**
71             * 返回结果示例
72             */
73            System.err.println("result:" + result);
74            JSONObject jsonObject = new JSONObject(result);
75            String access_token = jsonObject.getString("access_token");
76            return access_token;
77        } catch (Exception e) {
78            System.err.printf("获取token失败!");
79            e.printStackTrace(System.err);
80        }
81        return null;
82    }
83
84}1# encoding:utf-8
2import requests 
3
4# client_id 为官网获取的AK, client_secret 为官网获取的SK
5host = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=【官网获取的AK】&client_secret=【官网获取的SK】'
6response = requests.get(host)
7if response:
8    print(response.json())1#include <iostream>
2#include <curl/curl.h>
3#include <json/json.h>
4#include "access_token.h"
5// libcurl库下载链接:https://curl.haxx.se/download.html
6// jsoncpp库下载链接:https://github.com/open-source-parsers/jsoncpp/
7// 获取access_token所需要的url
8const std::string access_token_url = "https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials";
9// 回调函数获取到的access_token存放变量
10// static std::string access_token_result;
11/**
12 * curl发送http请求调用的回调函数,回调函数中对返回的json格式的body进行了解析,解析结果储存在result中
13 * @param 参数定义见libcurl库文档
14 * @return 返回值定义见libcurl库文档
15 */
16static size_t callback(void *ptr, size_t size, size_t nmemb, void *stream) {
17    // 获取到的body存放在ptr中,先将其转换为string格式
18    std::string s((char *) ptr, size * nmemb);
19    // 开始获取json中的access token项目
20    Json::Reader reader;
21    Json::Value root;
22    // 使用boost库解析json
23    reader.parse(s,root);
24    std::string* access_token_result = static_cast<std::string*>(stream);
25    *access_token_result = root["access_token"].asString();
26    return size * nmemb;
27}
28
29/**
30 * 用以获取access_token的函数,使用时需要先在百度云控制台申请相应功能的应用,获得对应的API Key和Secret Key
31 * @param access_token 获取得到的access token,调用函数时需传入该参数
32 * @param AK 应用的API key
33 * @param SK 应用的Secret key
34 * @return 返回0代表获取access token成功,其他返回值代表获取失败
35 */
36int get_access_token(std::string &access_token, const std::string &AK, const std::string &SK) {
37    CURL *curl;
38    CURLcode result_code;
39    int error_code = 0;
40    curl = curl_easy_init();
41    if (curl) {
42        std::string url = access_token_url + "&client_id=" + AK + "&client_secret=" + SK;
43        curl_easy_setopt(curl, CURLOPT_URL, url.data());
44        curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0);
45        curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0);
46        std::string access_token_result;
47        curl_easy_setopt(curl, CURLOPT_WRITEDATA, &access_token_result);
48        curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, callback);
49        result_code = curl_easy_perform(curl);
50        if (result_code != CURLE_OK) {
51            fprintf(stderr, "curl_easy_perform() failed: %s\n",
52                    curl_easy_strerror(result_code));
53            return 1;
54        }
55        access_token = access_token_result;
56        curl_easy_cleanup(curl);
57        error_code = 0;
58    } else {
59        fprintf(stderr, "curl_easy_init() failed.");
60        error_code = 1;
61    }
62    return error_code;
63}1using System;
2using System.Collections.Generic;
3using System.Net.Http;
4
5namespace com.baidu.ai
6{
7    public static class AccessToken
8
9    {
10        // 调用getAccessToken()获取的 access_token建议根据expires_in 时间 设置缓存
11        // 返回token示例
12        public static String TOKEN = "24.adda70c11b9786206253ddb70affdc46.2592000.1493524354.282335-1234567";
13
14        // 百度云中开通对应服务应用的 API Key 建议开通应用的时候多选服务
15        private static String clientId = "百度云应用的AK";
16        // 百度云中开通对应服务应用的 Secret Key
17        private static String clientSecret = "百度云应用的SK";
18
19        public static String getAccessToken() {
20            String authHost = "https://aip.baidubce.com/oauth/2.0/token";
21            HttpClient client = new HttpClient();
22            List<KeyValuePair<String, String>> paraList = new List<KeyValuePair<string, string>>();
23            paraList.Add(new KeyValuePair<string, string>("grant_type", "client_credentials"));
24            paraList.Add(new KeyValuePair<string, string>("client_id", clientId));
25            paraList.Add(new KeyValuePair<string, string>("client_secret", clientSecret));
26
27            HttpResponseMessage response = client.PostAsync(authHost, new FormUrlEncodedContent(paraList)).Result;
28            String result = response.Content.ReadAsStringAsync().Result;
29            Console.WriteLine(result);
30            return result;
31        }
32    }
33}1var https = require('https');
2var qs = require('querystring');
3
4const param = qs.stringify({
5    'grant_type': 'client_credentials',
6    'client_id': '您的 Api Key',
7    'client_secret': '您的 Secret Key'
8});
9
10https.get(
11    {
12        hostname: 'aip.baidubce.com',
13        path: '/oauth/2.0/token?' + param,
14        agent: false
15    },
16    function (res) {
17        // 在标准输出中查看运行结果
18        res.pipe(process.stdout);
19    }
20);注意:
access_token的有效期为30天,切记需要每30天进行定期更换,或者每次请求都拉取新token;
例如此接口,使用HTTPS POST发送:
1https://aip.baidubce.com/rest/2.0/face/v1/merge?access_token=24.f9ba9c5341b67688ab4added8bc91dec.2592000.1485570332.282335-8574074POST中Body的参数,按照下方请求参数说明选择即可。
提示:如果您为百度云老用户,正在使用其他非AI的服务,可以参考百度云AKSK鉴权方式发送请求,虽然请求方式和鉴权方法和本文所介绍的不同,但请求参数和返回结果一致。
请求说明
注意事项:
- 请求体格式化:Content-Type为application/json,通过json格式化请求体。
- Base64编码:请求的图片需经过Base64编码,图片的base64编码指将图片数据编码成一串字符串,使用该字符串代替图像地址。您可以首先得到图片的二进制,然后用Base64格式编码即可。需要注意的是,图片的base64编码是不包含图片头的,如data:image/jpg;base64,
- 图片格式:现支持PNG、JPG、JPEG、BMP,不支持GIF图片
- 人脸识别接口分为V2和V3两个版本,本文档为V3版本接口的说明文档,请确认您在百度云后台获得的是V3版本接口权限,再来阅读本文档。
辨别接口版本的方法是:在百度云后台进入【应用列表】,点击【应用名称】,在【API列表】中可以看到【请求地址】,若请求地址中带有【v3】标识,则您具有的是v3权限,可以阅读本文档;若请求地址中带有【v2】标识,则您具有的是v2权限,应该去阅读v2文档。
请求示例
HTTP方法:POST
请求URL: https://aip.baidubce.com/rest/2.0/face/v3/matchsec
URL参数:
| 参数 | 值 | 
|---|---|
| access_token | 通过API Key和Secret Key获取的access_token,参考“Access Token获取” | 
Header如下:
| 参数 | 值 | 
|---|---|
| Content-Type | application/json | 
Body中放置请求参数,参数详情如下:
请求参数
| 参数 | 必选 | 类型 | 说明 | 
|---|---|---|---|
| image | 是 | string | 采集SDK4.1版本上传的加密图片Base64信息 | 
| image_type | 是 | string | 图片类型 BASE64:图片的base64值,base64编码后的图片数据,编码后的图片大小不超过2M; | 
| face_type | 否 | string | 人脸的类型 LIVE:表示生活照:通常为手机、相机拍摄的人像图片、或从网络获取的人像图片等, IDCARD:表示身份证芯片照:二代身份证内置芯片中的人像照片, WATERMARK:表示带水印证件照:一般为带水印的小图,如公安网小图 CERT:表示证件照片:如拍摄的身份证、工卡、护照、学生证等证件图片 INFRARED 表示红外照片:使用红外相机拍摄的照片 默认LIVE | 
| quality_control | 否 | string | 图片质量控制 NONE: 不进行控制 LOW:较低的质量要求 NORMAL: 一般的质量要求 HIGH: 较高的质量要求 默认 NONE 若图片质量不满足要求,则返回结果中会提示质量检测失败 | 
| liveness_control | 否 | string | 活体检测控制 NONE: 不进行控制 LOW:较低的活体要求(高通过率 低攻击拒绝率) NORMAL: 一般的活体要求(平衡的攻击拒绝率, 通过率) HIGH: 较高的活体要求(高攻击拒绝率 低通过率) 默认 NONE 若活体检测结果不满足要求,则返回结果中会提示活体检测失败 | 
| face_sort_type | 否 | int | 人脸检测排序类型 0:代表检测出的人脸按照人脸面积从大到小排列 1:代表检测出的人脸按照距离图片中心从近到远排列 默认为0 | 
| register_image | 是 | string | 图片信息(总数据大小应小于10M),图片上传方式根据image_type来判断。本图片特指客户服务器上传图片,非加密图片Base64值 | 
| register_image_type | 是 | string | 图片类型 BASE64:图片的base64值,base64编码后的图片数据,编码后的图片大小不超过2M; URL:图片的 URL地址( 可能由于网络等原因导致下载图片时间过长); FACE_TOKEN: 人脸图片的唯一标识,调用人脸检测接口时,会为每个人脸图片赋予一个唯一的FACE_TOKEN,同一张图片多次检测得到的FACE_TOKEN是同一个。 | 
| register_face_type | 否 | string | 人脸的类型 LIVE:表示生活照:通常为手机、相机拍摄的人像图片、或从网络获取的人像图片等, IDCARD:表示身份证芯片照:二代身份证内置芯片中的人像照片, WATERMARK:表示带水印证件照:一般为带水印的小图,如公安网小图 CERT:表示证件照片:如拍摄的身份证、工卡、护照、学生证等证件图片 INFRARED 表示红外照片:使用红外相机拍摄的照片 默认LIVE | 
| register_quality_control | 否 | string | 图片质量控制 NONE: 不进行控制 LOW:较低的质量要求 NORMAL: 一般的质量要求 HIGH: 较高的质量要求 默认 NONE 若图片质量不满足要求,则返回结果中会提示质量检测失败 | 
| register_liveness_control | 否 | string | 活体检测控制 NONE: 不进行控制 LOW:较低的活体要求(高通过率 低攻击拒绝率) NORMAL: 一般的活体要求(平衡的攻击拒绝率, 通过率) HIGH: 较高的活体要求(高攻击拒绝率 低通过率) 默认 NONE 若活体检测结果不满足要求,则返回结果中会提示活体检测失败 | 
| risk_identify | 否 | boolean | 是否进行风险识别 默认False Ture:打开风险识别。(接受SDK端传入的指纹信息,返回识别结果) False:关闭风险识别。 | 
| ip | 否 | string | 需要风控判别的ip地址 | 
| phone | 否 | string | 需要风控判别的手机号 | 
说明:两张图片的上传使用json格式,如下:
JSON1{ 2 "image": "image", //采集SDK4.1传入的加密后的图片BASE64信息 3 "image_type": "BASE64", 4 "face_type": "LIVE", 5 "quality_control": "LOW", 6 "liveness_control": "HIGH", 7 8 "register_image": "image", //服务端传入的非加密图片的BASE64 9 "register_image_type": "BASE64", 10 "register_face_type": "LIVE", 11 "register_quality_control": "LOW", 12 "register_liveness_control": "HIGH", 13 14 "risk_identify": "Ture", 15 "ip": "...ip", 16 "phone": "...phone" 17 18}
返回说明
返回参数
| 参数名 | 必选 | 类型 | 说明 | 
|---|---|---|---|
| score | 是 | float | 人脸相似度得分,推荐阈值80分 | 
| face_list | 是 | array | 人脸信息列表 | 
| +face_token | 是 | string | 人脸的唯一标志 | 
| +risk_level | 否 | string | 判断设备是否发生过风险行为来判断风险级别,取值(数值有高到低): 1 – 高危 2 – 嫌疑 3 – 普通 4 – 正常 | 
| +risk_tag | 否 | string | 风险标签,若判断未为有风险,则会有风险标签jason 数组告知风险类型 | 
| +risk_warn_code | 否 | int | 风控服务异常,请重试若多次重试后无效,请提交工单咨询 | 
- 
返回示例 JSON1 "result": { 2 "score": 21.58333969, 3 "face_list": [ 4 { 5 "face_token": "470795667ddb21e38908cf3dc31dcdec" 6 }, 7 { 8 "face_token": "605a1fb2a02f4886490db3e4b5f6f0c9" 9 } 10 ], 11 "verify_status": 0 12 }, 13 "risk_level": "1", 14 "log_id": 1349004812288524288, 15 "risk_tag": [ 16 "general_inject" 17 ] 18}
- 质量控制参数说明
不同的控制度下所对应的质量控制阈值,如果检测出来的质量信息某一项不符合控制阈值的要求,则会返回错误信息。
遮挡情况的阈值
| 控制度 | left_eye | right_eye | nose | mouth | left_cheek | right_cheek | chin_contour | 
|---|---|---|---|---|---|---|---|
| LOW | 0.8 | 0.8 | 0.8 | 0.8 | 0.8 | 0.8 | 0.8 | 
| NORMAL | 0.6 | 0.6 | 0.6 | 0.6 | 0.6 | 0.6 | 0.6 | 
| HIGH | 0.2 | 0.2 | 0.2 | 0.2 | 0.2 | 0.2 | 0.2 | 
光照、模糊度、完整度的阈值
| 控制度 | illumination | blurdegree | completeness | 
|---|---|---|---|
| LOW | 20 | 0.8 | 0 | 
| NORMAL | 40 | 0.6 | 0 | 
| HIGH | 100 | 0.2 | 1 | 
活体控制参数说明
不同的控制度下所对应的活体控制阈值,如果检测出来的活体分数小于控制阈值,则会返回错误信息。
| 控制度 | 阈值 | 说明 | 
|---|---|---|
| LOW | 0.05 | 活体误拒率:万分之一;拒绝率:97.75% | 
| NORMAL | 0.3 | 活体误拒率:千分之一;拒绝率:98.82% | 
| HIGH | 0.9 | 活体误拒率:百分之一;拒绝率:99.77% | 
1、误拒率: 把真人识别为假人的概率. 阈值越高,安全性越高, 要求也就越高, 对应的误识率就越高
2、通过率=1-误拒率
关于以上数值的概念介绍:
拒绝率(TRR):如99%,代表100次作弊假体攻击,会有99次被拒绝。 误拒率(FRR):如0.5%,指1000次真人请求,会有5次因为活体分数低于阈值被错误拒绝。 通过率(TAR):如99%,指100次真人请求,会有99次因为活体分数高于阈值而通过。 阈值(Threshold):高于此数值,则可判断为活体。
错误码
请参考人脸识别错误码
