接口說明
基于科大訊飛自研的人臉算法,可實現對比兩張照片中的人臉信息,判斷是否是同一個人并返回相似度得分。
集成人臉比對API時,需按照以下要求:
內容 | 說明 |
---|---|
傳輸方式 | http[s] (為提高安全性,強烈推薦https) |
請求地址 |
http[s]: //api.xf-yun.com/v1/private/s67c9c78c 注:服務器IP不固定,為保證您的接口穩定,請勿通過指定IP的方式調用接口,使用域名方式調用 |
請求行 | POST /v1/private/s67c9c78c HTTP/1.1 |
接口鑒權 | 簽名機制,詳情請參照下方鑒權認證 |
字符編碼 | UTF-8 |
響應格式 | 統一采用JSON格式 |
開發語言 | 任意,只要可以向訊飛云服務發起HTTP請求的均可 |
適用范圍 | 任意操作系統,但因不支持跨域不適用于瀏覽器 |
圖片格式 | jpg/png/bmp |
圖片大小 | base64編碼后大小不超過4M |
圖片要求 | 清晰的人臉照片,人臉大小不小于30*30像素,其中人臉俯仰角、左右偏航角、人臉翻轉角60°以內識別效果更好 |
#鑒權說明
在調用業務接口時,請求方需要對請求進行簽名,服務端通過簽名來校驗請求的合法性。 通過在請求地址后面加上鑒權相關參數的方式,參數具體如下: http示例url:
https://api.xf-yun.com/v1/private/s67c9c78c?authorization=YXBpX2tleT0iYXBpa2V5WFhYWFhYWFhYWFhYWFhYWFhYWFhYWFhYWFgiLCBhbGdvcml0aG09ImhtYWMtc2hhMjU2IiwgaGVhZGVycz0iaG9zdCBkYXRlIHJlcXVlc3QtbGluZSIsIHNpZ25hdHVyZT0iSk5od3prMWtLYjUwdUVGbEUxS2xCbk83K09NTjNZUk5LZVFsYzVMYVltTT0i&host=api.xf-yun.com&date=Fri%2C+17+Jul+2020+06%3A26%3A58+GMT
鑒權參數:
參數 | 類型 | 必須 | 說明 | 示例 |
---|---|---|---|---|
host | string | 是 | 請求主機 | api.xf-yun.com |
date | string | 是 | 當前時間戳,RFC1123格式("EEE, dd MMM yyyy HH:mm:ss z") | Fri, 17 Jul 2020 06:26:58 GMT |
authorization | string | 是 | 使用base64編碼的簽名相關信息(簽名基于hamc-sha256計算) | 參考下方詳細生成規則 |
? date參數生成規則:
date必須是UTC+0或GMT時區,RFC1123格式(Fri, 17 Jul 2020 06:26:58 GMT)。
服務端會對date進行時鐘偏移檢查,最大允許300秒的偏差,超出偏差的請求都將被拒絕。
? authorization參數生成格式:
1)獲取接口密鑰APIKey 和 APISecret。
在訊飛開放平臺控制臺,創建一個應用后打開人臉比對頁面可以獲取,均為32位字符串。
2)參數authorization base64編碼前(authorization_origin)的格式如下。
api_key="$api_key",algorithm="hmac-sha256",headers="host date request-line",signature="$signature"
其中 api_key 是在控制臺獲取的APIKey,algorithm 是加密算法(僅支持hmac-sha256),headers 是參與簽名的參數(見下方注釋)。
signature 是使用加密算法對參與簽名的參數簽名后并使用base64編碼的字符串,詳見下方。
注: headers是參與簽名的參數,請注意是固定的參數名("host date request-line"),而非這些參數的值。
3)signature的原始字段(signature_origin)規則如下。
signature原始字段由 host,date,request-line三個參數按照格式拼接成,
拼接的格式為(\n為換行符,’:’后面有一個空格):
host: $host\ndate: $date\n$request-line
假設
請求url = api.xf-yun.com
date = Fri, 17 Jul 2020 06:26:58 GMT
那么 signature原始字段(signature_origin)則為:
host: api.xf-yun.com
date: Fri, 17 Jul 2020 06:26:58 GMT
POST /v1/private/s67c9c78c HTTP/1.1
4)使用hmac-sha256算法結合apiSecret對signature_origin簽名,獲得簽名后的摘要signature_sha。
signature_sha=hmac-sha256(signature_origin,$apiSecret)
其中 apiSecret 是在控制臺獲取的APISecret
5)使用base64編碼對signature_sha進行編碼獲得最終的signature。
signature=base64(signature_sha)
假設
APISecret = apisecretXXXXXXXXXXXXXXXXXXXXXXX
date = Fri, 17 Jul 2020 06:26:58 GMT
則signature為
signature=JNhwzk1kKb50uEFlE1KlBnO7+OMN3YRNKeQlc5LaYmM=
6)根據以上信息拼接authorization base64編碼前(authorization_origin)的字符串,示例如下。
api_key="apikeyXXXXXXXXXXXXXXXXXXXXXXXXXX", algorithm="hmac-sha256", headers="host date request-line", signature="JNhwzk1kKb50uEFlE1KlBnO7+OMN3YRNKeQlc5LaYmM="
注: headers是參與簽名的參數,請注意是固定的參數名("host date request-line"),而非這些參數的值。
7)最后再對authorization_origin進行base64編碼獲得最終的authorization參數。
authorization = base64(authorization_origin)
示例:
authorization=YXBpX2tleT0iYXBpa2V5WFhYWFhYWFhYWFhYWFhYWFhYWFhYWFhYWFgiLCBhbGdvcml0aG09ImhtYWMtc2hhMjU2IiwgaGVhZGVycz0iaG9zdCBkYXRlIHJlcXVlc3QtbGluZSIsIHNpZ25hdHVyZT0iSk5od3prMWtLYjUwdUVGbEUxS2xCbk83K09NTjNZUk5LZVFsYzVMYVltTT0i
#鑒權結果
如果鑒權失敗,則根據不同錯誤類型返回不同HTTP Code狀態碼,同時攜帶錯誤描述信息,詳細錯誤說明如下:
HTTP Code | 說明 | 錯誤描述信息 | 解決方法 |
---|---|---|---|
401 | 缺少authorization參數 | {"message":"Unauthorized"} | 檢查是否有authorization參數,詳情見authorization參數詳細生成規則 |
401 | 簽名參數解析失敗 | {“message”:”HMAC signature cannot be verified”} | 檢查簽名的各個參數是否有缺失是否正確,特別確認下復制的api_key是否正確 |
401 | 簽名校驗失敗 | {“message”:”HMAC signature does not match”} |
簽名驗證失敗,可能原因有很多。 1. 檢查api_key,api_secret 是否正確。 2.檢查計算簽名的參數host,date,request-line是否按照協議要求拼接。 3. 檢查signature簽名的base64長度是否正常(正常44個字節)。 |
403 | 時鐘偏移校驗失敗 | {“message”:”HMAC signature cannot be verified, a valid date or x-date header is required for HMAC Authentication”} | 檢查服務器時間是否標準,相差5分鐘以上會報此錯誤 |
認證失敗返回示例:
HTTP/1.1 403 Forbidden
Date: Thu, 06 Dec 2018 07:55:16 GMT
Content-Length: 116
Content-Type: text/plain; charset=utf-8
{
"message": "HMAC signature does not match"
}
#請求參數
在調用業務接口時,都需要在 Http Request Body 中配置以下參數,請求數據均為json字符串。
請求參數示例:
{
"header": {
"app_id": "XXXXXXXX",
"status": 3
},
"parameter": {
"s67c9c78c": {
"service_kind": "face_compare",
"face_compare_result": {
"encoding": "utf8",
"compress": "raw",
"format": "json"
}
}
},
"payload": {
"input1": {
"encoding": "jpg",
"status": 3,
"image": "/4AAQSkZJRgA..."
},
"input2": {
"encoding": "jpg",
"status": 3,
"image": "/9j/4AAQSkZJ..."
}
}
}
請求參數說明:
參數名 | 類型 | 必傳 | 描述 |
---|---|---|---|
header | object | 是 | 用于上傳平臺參數 |
header.app_id | string | 是 | 在平臺申請的appid信息 |
header.status | string | 是 | 請求狀態,取值范圍為:3(一次傳完) |
parameter | object | 是 | 用于上傳服務特性參數 |
parameter.s67c9c78c | object | 是 | 用于上傳功能參數 |
parameter.s67c9c78c.service_kind | string | 是 | 請求功能類型,取值范圍為:face_compare |
parameter.s67c9c78c.face_compare_result | object | 是 | 用于上傳響應數據參數 |
parameter.s67c9c78c.face_compare_result.encoding | string | 否 | 文本編碼,可選值:utf8(默認值) |
parameter.s67c9c78c.face_compare_result.compress | string | 否 | 文本壓縮格式,可選值:raw(默認值) |
parameter.s67c9c78c.face_compare_result.format | string | 否 | 文本格式,可選值:json(默認值) |
payload | object | 是 | 用于上傳請求數據 |
payload.input1 | object | 是 | 用于上傳第一張圖像數據 |
payload.input1.encoding | string | 否 |
第一張圖像編碼 可選值: jpg:jpg格式(默認值) jpeg:jpeg格式 png:png格式 bmp:bmp格式 |
payload.input1.image | string | 是 | 第一張圖像數據,base64編碼,需保證圖像文件大小base64編碼后不超過4MB |
payload.input1.status | int | 否 | 第一張數據狀態,取值范圍為:3(一次傳完) |
payload.input2 | object | 是 | 用于上傳第二張圖像數據 |
payload.input2.encoding | string | 否 |
第二張圖像編碼 可選值: jpg:jpg格式(默認值) jpeg:jpeg格式 png:png格式 bmp:bmp格式 |
payload.input2.image | string | 是 | 第二張圖像數據,base64編碼,需保證圖像文件大小base64編碼后不超過4MB |
payload.input2.status | int | 否 | 第二張數據狀態,取值范圍為:3(一次傳完) |
#返回結果
如出現錯誤碼,可到 這里 查詢。
返回參數示例:
{
"header": {
"code": 0,
"message": "success",
"sid": "asexxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
},
"payload": {
"face_compare_result": {
"compress": "raw",
"encoding": "utf8",
"format": "json",
"text": "ewoJInJldCIgOiAwLAoJInNjb3JlIiA6IDAuOTk2MTg2MDc3NTk0NzU3MDgKfQo="
}
}
}
返回參數說明:
參數名 | 類型 | 描述 |
---|---|---|
header | object | 協議頭部,用于描述平臺特性的參數 |
header.sid | string | 本次會話id |
header.code | int |
返回碼 0表示會話調用成功(并不一定表示服務調用成功,服務是否調用成功以text字段中的ret為準) 其它表示會話調用異常,詳情請參考錯誤碼。 |
header.message | string | 描述信息 |
payload | object | 數據段,用于攜帶響應的數據 |
payload.face_compare_result | object | 人臉比對響應數據塊 |
payload.face_compare_result.compress | string | 文本壓縮格式,僅在設置了parameter.s67c9c78c.face_compare_result.compress參數時返回 |
payload.face_compare_result.encoding | string | 文本編碼,僅在設置了parameter.s67c9c78c.face_compare_result.encoding參數時返回 |
payload.face_compare_result.format | string | 文本格式,僅在設置了parameter.s67c9c78c.face_compare_result.format參數時返回 |
payload.face_compare_result.text | string | 人臉比對返回結果,需要對其進行base64解碼,解碼后的返回字段如下 |
text字段base64解碼示例
{
"ret" : 0,
"score" : 0.99618607759475708
}
text字段參數說明:
參數名 | 類型 | 描述 | 備注 |
---|---|---|---|
ret | int | 內部服務返回值 | ret=0表示請求成功,否則請參考錯誤碼表 |
score | float | 人臉相似度 |
最小值:0 最大值:1。 建議高于0.67認為是同一個人。 建議使用僅包含一張人臉的照片進行比對,若照片中含有多張人臉,引擎會選擇其中人臉置信度最高的人臉進行比較,可能會影響比對結果。 |
#常見問題
#人臉比對的主要功能是什么?
答:人臉比對可以對比兩張照片中的人臉信息,判斷是否是同一個人。
#人臉比對支持什么應用平臺?
答:目前支持Web API應用平臺。
#人臉比對對人臉有什么要求嗎?
答:需要清晰的人臉照片,人臉大小不小于30*30像素,其中人臉俯仰角、左右偏航角、人臉翻轉角60°以內識別效果更好。
-
API
+關注
關注
2文章
1502瀏覽量
62117 -
人臉識別
+關注
關注
76文章
4012瀏覽量
81968 -
python
+關注
關注
56文章
4797瀏覽量
84773 -
科大訊飛
+關注
關注
19文章
804瀏覽量
61301
發布評論請先 登錄
相關推薦
評論