Web API 文档
接口说明
温馨提示:声纹识别服务已升级,请新老用户尽快切换到此WebAPI接口,感谢理解与支持!
**1、创建声纹特征库(必须)
****2、添加音频特征(必须)
****3、特征比对1:1(必须)
****4、特征比对1:N(必须)
**5、查询特征列表(非必须)
6、更新音频特征(非必须)
7、删除指定特征(非必须)
8、删除声纹特征库(非必须)
#接口Demo
demo 覆盖部分语言,其他语言参照下方接口文档进行开发。
欢迎热心的开发者到讯飞开放平台社区 分享你们的demo。
#接口要求
内容 | 说明 |
---|---|
传输方式 | http[s] (为提高安全性,强烈推荐https) |
请求地址 | http[s]: //api.xf-yun.com/v1/private/s782b4996 注:服务器IP不固定,为保证您的接口稳定,请勿通过指定IP的方式调用接口,使用域名方式调用 |
请求行 | POST /v1/private/s782b4996 HTTP/1.1 |
接口鉴权 | 签名机制,详情请参照下方鉴权认证 |
字符编码 | UTF-8 |
响应格式 | 统一采用JSON格式 |
开发语言 | 任意,只要可以向讯飞云服务发起HTTP请求的均可 |
适用范围 | 任意操作系统,但因不支持跨域不适用于浏览器 |
音频格式 | 采样率16k、位长16bit、单声道的mp3 |
音频大小 | base64编码后大小不超过4M,音频内容请尽量保持清 晰,且有效帧大于0.5s(建议使用3-5秒的音频) |
#接口调用流程
• 将请求参数以及图片数据放在Http Request Body中,以POST表单的形式提交,详见下方 请求参数 。
• 向服务器端发送Http请求后,接收服务器端的返回结果。
#鉴权认证
#鉴权方法
https://api.xf-yun.com/v1/private/s782b4996?authorization=YXBpX2tleT0iYXBpa2V5WFhYWFhYWFhYWFhYWFhYWFhYWFhYWFhYWFgiLCBhbGdvcml0aG09ImhtYWMtc2hhMjU2IiwgaGVhZGVycz0iaG9zdCBkYXRlIHJlcXVlc3QtbGluZSIsIHNpZ25hdHVyZT0iMWp3UWJJQUttUUU3SndJSDBJRHhpQzFwZWpybE4rVnBIWERXT0ZWeTVOTT0i&host=api.xf-yun.com&date=Fri%2C+23+Apr+2021+02%3A35%3A47+GMT
参数 | 类型 | 必须 | 说明 | 示例 |
---|---|---|---|---|
host | string | 是 | 请求主机 | api.xf-yun.com |
date | string | 是 | 当前时间戳,RFC1123格式("EEE, dd MMM yyyy HH:mm:ss z") | Fri, 23 Apr 2021 02:35:47 GMT |
authorization | string | 是 | 使用base64编码的签名相关信息(签名基于hamc-sha256计算) | 参考下方详细生成规则 |
服务端会对date进行时钟偏移检查,最大允许300秒的偏差,超出偏差的请求都将被拒绝。
在讯飞开放平台控制台,创建一个应用后即可获取,均为32位字符串。
2)参数authorization base64编码前(authorization_origin)的格式如下。
api_key="$api_key",algorithm="hmac-sha256",headers="host date request-line",signature="$signature"
signature 是使用加密算法对参与签名的参数签名后并使用base64编码的字符串,详见下方。
拼接的格式为(\n为换行符,’:’后面有一个空格):
host: $host\ndate: $date\n$request-line
请求url = "https://api.xf-yun.com/v1/private/s782b4996"
date = "Fri, 23 Apr 2021 02:35:47 GMT"
host: api.xf-yun.com
date: Fri, 23 Apr 2021 02:35:47 GMT
POST /v1/private/s782b4996 HTTP/1.1
signature_sha=hmac-sha256(signature_origin,$apiSecret)
signature=base64(signature_sha)
APISecret = "apisecretXXXXXXXXXXXXXXXXXXXXXXX"
date = "Fri, 23 Apr 2021 02:35:47 GMT"
signature="1jwQbIAKmQE7JwIH0IDxiC1pejrlN+VpHXDWOFVy5NM="
api_key="apikeyXXXXXXXXXXXXXXXXXXXXXXXXXX", algorithm="hmac-sha256", headers="host date request-line", signature="1jwQbIAKmQE7JwIH0IDxiC1pejrlN+VpHXDWOFVy5NM="
authorization = base64(authorization_origin)
示例结果为:
authorization=YXBpX2tleT0iYXBpa2V5WFhYWFhYWFhYWFhYWFhYWFhYWFhYWFhYWFgiLCBhbGdvcml0aG09ImhtYWMtc2hhMjU2IiwgaGVhZGVycz0iaG9zdCBkYXRlIHJlcXVlc3QtbGluZSIsIHNpZ25hdHVyZT0iMWp3UWJJQUttUUU3SndJSDBJRHhpQzFwZWpybE4rVnBIWERXT0ZWeTVOTT0i
#鉴权结果
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: Mon, 30 Nov 2020 02:34:33 GMT
Content-Length: 116
Content-Type: text/plain; charset=utf-8
{
"message": "HMAC signature does not match, a valid date or x-date header is required for HMAC Authentication"
}
#请求参数(创建声纹特征库)
{
"header": {
"app_id": "your_app_id",
"status": 3
},
"parameter": {
"s782b4996": {
"func": "createGroup",
"groupId": "iFLYTEK_examples_groupId",
"groupName": "iFLYTEK_examples_groupName",
"groupInfo": "iFLYTEK_examples_groupInfo",
"createGroupRes": {
"encoding": "utf8",
"compress": "raw",
"format": "json"
}
}
}
}
参数名 | 类型 | 必传 | 描述 |
---|---|---|---|
header | object | 是 | 用于上传平台参数 |
header.app_id | string | 是 | 在平台申请的appid信息 |
header.status | int | 是 | 请求状态,取值为:3(一次传完) |
parameter | object | 是 | 用于上传服务特性参数 |
parameter.s782b4996 | object | 是 | 用于上传功能参数 |
parameter.s782b4996.func | string | 是 | 用于指定声纹的具体能力(创建声纹特征库值为createGroup) |
parameter.s782b4996.groupId | string | 是 | 创建分组的标识,支持字母数字下划线,长度最大为32 |
parameter.s782b4996.groupName | string | 否 | 创建分组的名称,长度最小为0,最大为256 |
parameter.s782b4996.groupInfo | string | 否 | 创建分组的描述信息,长度最小为0,最大为256 |
parameter.s782b4996.createGroupRes | object | 是 | 期望返回结果的格式 |
parameter.s782b4996.createGroupRes.encoding | string | 是 | 编码格式(固定utf-8) |
parameter.s782b4996.createGroupRes.compress | string | 是 | 压缩格式(固定raw) |
parameter.s782b4996.createGroupRes.format | string | 是 | 文本格式(固定json) |
#返回参数(创建声纹特征库)
{
"header": {
"code": 0,
"message": "success",
"sid": "ase000e55f5@hu178fca72b160210882"
},
"payload": {
"createGroupRes": {
"text": "eyJncm91cEl..."
}
}
}
{
"groupName": "iFLYTEK_examples_groupName",
"groupId": "iFLYTEK_examples_groupId",
"groupInfo": "iFLYTEK_examples_groupInfo"
}
参数名 | 类型 | 描述 |
---|---|---|
header | object | 用于传递平台参数 |
header.sid | string | 本次会话唯一标识id |
header.code | int | 0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。 |
header.message | string | 描述信息 |
payload | object | 数据段,用于携带响应的数据 |
payload.createGroupRes | object | 响应数据块 |
payload.createGroupRes.text | string | 响应数据base64编码 |
字段 | 类型 | 描述 | 备注 |
---|---|---|---|
groupId | string | 创建分组的唯一标识 | |
groupName | string | 创建分组的名称 | |
groupInfo | string | 创建分组的描述信息 |
#请求参数(添加音频特征)
{
"header": {
"app_id": "your_app_id",
"status": 3
},
"parameter": {
"s782b4996": {
"func": "createFeature",
"groupId": "iFLYTEK_examples_groupId",
"featureId": "iFLYTEK_examples_featureId",
"featureInfo": "iFLYTEK_examples_featureInfo",
"createFeatureRes": {
"encoding": "utf8",
"compress": "raw",
"format": "json"
}
}
},
"payload": {
"resource": {
"encoding": "lame",
"sample_rate": 16000,
"channels": 1,
"bit_depth": 16,
"status": 3,
"audio": "SUQzBAAAAAAAI1..."
}
}
}
参数名 | 类型 | 必传 | 描述 |
---|---|---|---|
header | object | 是 | 用于上传平台参数 |
header.app_id | string | 是 | 在平台申请的appid信息 |
header.status | int | 是 | 请求状态,取值为:3(一次传完) |
parameter | object | 是 | 用于上传服务特性参数 |
parameter.s782b4996 | object | 是 | 用于上传功能参数 |
parameter.s782b4996.func | string | 是 | 用于指定声纹的具体能力(添加音频特征值为createFeature) |
parameter.s782b4996.groupId | string | 是 | 分组的标识,支持字母数字下划线,长度最大为32 |
parameter.s782b4996.featureId | string | 是 | 特征的标识,长度最小为0,最大为32 |
parameter.s782b4996.featureInfo | string | 否 | 特征描述信息,长度最小为0,最大为256(建议在特征信息里加入时间戳) |
parameter.s782b4996.createFeatureRes | object | 是 | 期望返回结果的格式 |
parameter.s782b4996.createFeatureRes.encoding | string | 是 | 编码格式(固定utf-8) |
parameter.s782b4996.createFeatureRes.compress | string | 是 | 压缩格式(固定raw) |
parameter.s782b4996.createFeatureRes.format | string | 是 | 文本格式(固定json) |
payload | object | 是 | 用于上传请求数据 |
payload.resource | object | 是 | 用于相关音频相关参数 |
payload.resource.encoding | string | 是 | 音频编码(固定lame) |
payload.resource.sample_rate | int | 是 | 音频采样率(16000) |
payload.resource.channels | int | 否 | 音频声道数(1单声道) |
payload.resource.bit_depth | int | 否 | 音频位深(16) |
payload.resource.status | int | 是 | 音频数据状态(3一次性传完) |
payload.resource.audio | string | 是 | 音频数据base64编码(编码后最小长度:1B 最大长度:4M) |
#返回参数(添加音频特征)
{
"header": {
"code": 0,
"message": "success",
"sid": "ase000ec93e@hu178fd5902750212882"
},
"payload": {
"createFeatureRes": {
"text": "eyJmZWF0dXJl..."
}
}
}
{
"featureId": "iFLYTEK_examples_featureId"
}
参数名 | 类型 | 描述 |
---|---|---|
header | object | 用于传递平台参数 |
header.sid | string | 本次会话唯一标识id |
header.code | int | 0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。 |
header.message | string | 描述信息 |
payload | object | 数据段,用于携带响应的数据 |
payload.createFeatureRes | object | 响应数据块 |
payload.createFeatureRes.text | string | 响应数据base64编码 |
字段 | 类型 | 描述 | 备注 |
---|---|---|---|
featureId | string | 特征的唯一标识 |