科大讯飞
  1. 声纹识别
科大讯飞
  • iOS SDK接入文档
  • 平台文档
    • 开发者新手指南
      • 平台简介
      • 快速指引
    • 服务协议
      • 讯飞开放平台用户服务协议
      • 讯飞星火认知大模型接口服务协议
      • 开发者应用创建规则
      • 讯飞开放平台隐私政策
      • 开发者用户个人信息保护合规指引
      • 开放平台SDK合规使用说明
      • SDK隐私政策总览
      • SDK合规使用说明总览
      • 科大讯飞儿童隐私保护政策
      • 讯飞开放平台SLA协议
      • 讯飞开放平台订购协议
    • 用户认证须知
      • 用户认证简介
      • 企业实名认证
      • 个人实名认证
      • 初创团队认证
      • 学生认证
      • 公益项目认证
      • 个人升级企业认证
    • 财务
      • 退款规则及退款流程
      • 财务相关说明
    • 账号
      • 账号注销与删除流程
      • 账号与应用说明
    • 会员
      • 会员权益详情
      • 会员时效说明
      • 会员试用版
  • 星火认知大模型
    • SparkDesk
      • SparkDesk使用指南
      • SparkDesk隐私政策
      • SparkDesk用户协议
    • 星火认知大模型
      • 服务说明
      • 通用鉴权URL生成说明
      • Spark Android SDK接入文档
      • Linux SDK接入文档
      • Windows SDK接入文档
      • 讯飞星火认知大模型隐私政策
      • Web 文档
        • 星火认知大模型Web API文档
        • 星火大模型V1.5
        • 星火大模型V2
        • 星火大模型V3
    • 星火知识库
      • 星火知识库 API 文档
        • 星火知识库 API 文档
        • 文档问答
        • 文档上传
        • 文档总结
        • 获取文档总结/概要信息
      • 新版Embedding API文档
    • 图片生成
      • 图片生成 API
    • 图片理解
      • 图片理解 API
    • 大模型定制训练平台
      • 产品使用说明
      • 星火微调服务Web API文档文档
        • 星火微调服务Web API文档文档
        • V1.5版本
        • 微调模型
  • 语音识别
    • 语音唤醒(新版)
    • 语音听写
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • Java SDK 文档
      • 音频文件格式说明
      • 语音听写服务说明
      • 语音听写(流式版)SDK隐私政策
      • 语音听写(流式版)SDK合规使用说明
      • HarmonyOS SDK 文档
      • 语音听写自训练平台
      • 语音听写(流式版)WebAPI
    • 语音转写
      • 语音转写服务说明
      • 语音转写 服务协议
      • WebAPI 文档
        • 语音转写 API 文档
        • 文件上传
        • 查询结果
    • 极速语音转写
      • 极速语音转写 API 文档
      • 小文件上传
      • 初始化分块信息
      • 分块上传
      • 分块上传完成
      • 创建任务
      • 查询任务
    • 实时语音转写
      • 实时语音转写服务说明
      • 实时语音转写 API
    • 离线语音听写
      • Android SDK 文档
      • 离线语音听写服务说明
      • 离线语音听写SDK隐私政策
      • 离线语音听写SDK合规使用说明
    • 离线语音听写(新版)
      • Android SDK 文档
      • 离线语音听写隐私政策
    • 语音唤醒
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • 语音唤醒服务说明
      • 离线唤醒SDK隐私政策
    • 语音唤醒(新版)
      • Android SDK 文档
      • Linux SDK 文档
      • 语音唤醒隐私政策
    • 离线命令词识别
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • 离线命令词识别服务说明
      • 离线命令词识别SDK隐私政策
      • 离线命令词SDK合规使用说明
  • 语音合成
    • 在线语音合成
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • Java SDK 文档
      • 服务协议
      • 在线语音合成服务说明
      • 发音人自训练平台使用指南
      • WebAPI
    • 长文本语音合成
      • 长文本语音合成 API 文档
      • 创建任务
      • 查询任务
    • 离线语音合成
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • 服务协议
      • 离线语音合成服务说明
    • AI虚拟人技术
      • Web SDK 2.0 接入指南
      • Android-SDK
      • iOS-SDK
      • Web API 文档
        • AI虚拟人技术 API 文档
        • 音频驱动
        • 启动
        • 文本驱动
        • 停止
        • 心跳
  • 语音扩展
    • 语音评测(流式版)
      • 接口说明
      • Android SDK 文档
      • iOS SDK 文档
      • Linux SDK 文档
      • Windows SDK 文档
      • 语音评测SDK隐私政策
      • 语音评测(流式版)API
    • 语音评测suntone
      • 语音评测suntone API
    • 离线变声
      • Android SDK 集成文档
    • 音色转换
      • 音色转换 API
    • 性别年龄识别
      • 性别能力识别 API
    • 声纹识别
      • Web API 文档
      • 声纹识别 API
        POST
    • 歌曲识别
      • 歌曲识别 API
    • 歌曲识别 ACRCloud
      • 接口说明
      • 哼唱识别
      • 音乐识别
    • AI 客服中间件
      • 接口说明
      • 获取token
      • 查询配置
      • 直接外呼
      • 创建外呼任务
      • 提交任务数据
      • 启动外呼任务
      • 暂停外呼任务
      • 删除外呼任务
      • 查询任务
      • 结果数据推送
      • 话单推送
      • 录音推送
      • 会话推送
      • 呼入话术上下文动态数据获取
  • 自然语言处理
    • 文本纠错
      • 文本纠错 API
      • 黑白名单上传
    • 公文校队
      • 公文校对 API
    • 文本合规
      • 文本合规 API
      • 新增黑名单词库
      • 根据lib_id添加黑名单词条
      • 根据lib_id查询词条明细
      • 根据lib_id删除词条
      • 根据appid查询账户下所有词库
      • 根据lib_id删除词库
      • 创建白名单库
      • 根据lib_id添加放行词条
      • 根据lib_id查询词条详情
      • 根据lib_id删除词条信息
      • 根据appid查询所有词库列表
      • 根据lib_id删除词库
    • 图片合规
      • 图片合规 API
    • 音频合规
      • 音频合规 API
    • 视频合规
      • 视频合规 API
    • 文本改写
      • 文本改写 API
    • 机器翻译
      • 机器翻译(新) API
    • 机器翻译niutrans
      • 机器翻译niutrans API
    • 同声传译
      • 同声传译 API 
    • 离线分词
      • Android SDK 文档
  • 人脸识别
    • 人脸验证与检索
      • Android SDK 文档
      • iOS SDK 文档
      • 人脸验证与检索SDK隐私政策
      • 人脸验证与检索SDK合规使用说明
    • 人脸对比
      • 人脸比对 API
    • 人脸比对sensetime
      • 人脸比对sensetime API
    • 人脸水印照比对
      • 人脸水印照比对 API
    • 静默活体检测
      • 静默活体检测 API
    • 配合式活体检测
      • 配合式活体检测 API
    • 静默活体检测sensetime
      • 静默活体检测sensetime API
    • 人脸检测和属性分析
      • 人脸检测和属性分析 API
    • 人脸特征分析tuputech
      • 年龄 API
      • 颜值 API
      • 性别 API
      • 表情 API
  • 文字识别
    • 通用文字识别
      • 通用文字识别 API
    • 通用文字识别
      • 通用文字识别 intsig API
    • 手写文字识别
      • 手写文字识别 API
    • 印刷文字识别
      • 印刷文字识别 API
    • 印刷文字识别(多语种)
      • 印刷文字识别(多语种)
    • 印刷文字识别(多语种)intsig
      • 印刷文字识别(多语种)intsig API
    • 图片文档还原
      • 图片文档还原 API 
    • 国内通用票据识别
      • 接口说明
      • 国内通用票据识别 API
    • 离线OCR
      • Android SDK 文档
    • 名片识别 intsig
      • 名片识别 API
    • 身份证识别 intsig
      • 身份证识别 intsig API
    • 银行卡识别 intsig
      • 银行卡识别 API
    • 营业执照识别 intsig
      • 营业执照识别 intsig API
    • 增值税发票识别 intsig
      • 增值税发票识别 intsig API
    • 拍照速算识别
      • 接口说明
      • 拍照速算识别 API
    • 公式识别
      • 接口说明
      • 公式识别 API
    • 指尖文字识别
      • 接口说明
      • 指尖文字识别 API
    • 身份证识别
      • 接口说明
      • 身份证识别 API
    • 增值税发票识别
      • 接口说明
      • 增值税发票识别 API
    • 营业执照识别
      • 接口说明
      • 营业执照识别 API
    • 火车票识别
      • 接口说明
      • 火车票识别 API
    • 出租车发票识别
      • 接口说明
      • 出租车发票识别 API
  • 图像识别
    • 场景识别
      • 场景识别 API
    • 物体识别
      • 物体识别 API
    • 场所识别
      • 场所识别 API 文档
  • 基础服务
    • 云服务器 CVM
      • 云服务器 CVM 产品简介
      • 快速入门
      • 服务协议
  • 解决方案
    • 签到解决方案
      • SaaS操作文档
    • 智能硬件通用方案
      • 智能硬件通用方案说明
      • 麦克风阵列Android SDK
      • 麦克风阵列Linux SDK
      • 双麦阵列设计参考
      • 麦克风阵列录音要求
      • 语音唤醒Android SDK
      • 语音唤醒Linux SDK
      • 离线声纹Android SDK
      • 离线声纹Linux SDK
  • MSC API 文档
    • Android
      • 文件列表
      • SDK初始化
      • 语音识别(Recognizer)
      • 语音合成(Synthesizer)
      • 语音评测(Evaluator)
      • 语音唤醒(Wakeuper)
      • 声纹人脸(Verifier)
      • Android 常量字段值
      • 基础类
    • IOS
      • 文件列表
      • SDK初始化
      • 语音识别(Recognizer)
      • 语音合成(Synthesizer)
      • 语音评测(Evaluator)
      • 语音唤醒(Wakeuper)
      • 声纹人脸(Verifier)
      • 基础类
    • Windows&Linux
      • 文件列表
      • API 文档
    • Java
      • 所有类列表
      • SDK初始化
      • 语音识别(Recognizer)
      • 语音合成(Synthesizer)
      • 常量字段值
      • 基础类
  1. 声纹识别

Web API 文档

接口说明#

声纹识别(Voiceprint Recognition),是一项提取说话人声音特征和说话内容信息,自动核验说话人身份的技术。可以将说话人声纹信息与库中的已知用户声纹进行1:1比对验证和1:N的检索,当声纹匹配时即为验证/检索成功。
温馨提示:声纹识别服务已升级,请新老用户尽快切换到此WebAPI接口,感谢理解与支持!
调用过程中涉及步骤如下:
**1、创建声纹特征库(必须)
****2、添加音频特征(必须)
****3、特征比对1:1(必须)
****4、特征比对1:N(必须)
**5、查询特征列表(非必须)
6、更新音频特征(非必须)
7、删除指定特征(非必须)
8、删除声纹特征库(非必须)

#接口Demo#

示例demo请点击 这里 下载。
demo 覆盖部分语言,其他语言参照下方接口文档进行开发。
欢迎热心的开发者到讯飞开放平台社区 分享你们的demo。

#接口要求#

集成声纹识别API时,需按照以下要求。
内容说明
传输方式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秒的音频)

#接口调用流程#

• 通过接口密钥基于hmac-sha256计算签名,将签名以及其他参数加在请求地址后面。详见下方 鉴权认证 。
• 将请求参数以及图片数据放在Http Request Body中,以POST表单的形式提交,详见下方 请求参数 。
• 向服务器端发送Http请求后,接收服务器端的返回结果。

#鉴权认证#

在调用业务接口时,请求方需要对请求进行签名,服务端通过签名来校验请求的合法性。

#鉴权方法#

通过在请求地址后面加上鉴权相关参数的方式,请注意影响鉴权结果的值有url、APISecret、APIKey、date,如果调试鉴权,请务必按照示例中给的值进行调试,具体参数如下:
http示例url:
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
鉴权参数:
参数类型必须说明示例
hoststring是请求主机api.xf-yun.com
datestring是当前时间戳,RFC1123格式("EEE, dd MMM yyyy HH:mm:ss z")Fri, 23 Apr 2021 02:35:47 GMT
authorizationstring是使用base64编码的签名相关信息(签名基于hamc-sha256计算)参考下方详细生成规则
• date参数生成规则:
date必须是UTC+0或GMT时区,RFC1123格式(Fri, 23 Apr 2021 02:35:47 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 = "https://api.xf-yun.com/v1/private/s782b4996"
date = "Fri, 23 Apr 2021 02:35:47 GMT"
那么 signature原始字段(signature_origin)则为:
host: api.xf-yun.com
date: Fri, 23 Apr 2021 02:35:47 GMT
POST /v1/private/s782b4996 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, 23 Apr 2021 02:35:47 GMT"
则signature为
signature="1jwQbIAKmQE7JwIH0IDxiC1pejrlN+VpHXDWOFVy5NM="
6)根据以上信息拼接authorization base64编码前(authorization_origin)的字符串,示例如下。
api_key="apikeyXXXXXXXXXXXXXXXXXXXXXXXXXX", algorithm="hmac-sha256", headers="host date request-line", signature="1jwQbIAKmQE7JwIH0IDxiC1pejrlN+VpHXDWOFVy5NM="
注: headers是参与签名的参数,请注意是固定的参数名("host date request-line"),而非这些参数的值。
7)最后再对authorization_origin进行base64编码获得最终的authorization参数。
authorization = base64(authorization_origin)
示例结果为:
authorization=YXBpX2tleT0iYXBpa2V5WFhYWFhYWFhYWFhYWFhYWFhYWFhYWFhYWFgiLCBhbGdvcml0aG09ImhtYWMtc2hhMjU2IiwgaGVhZGVycz0iaG9zdCBkYXRlIHJlcXVlc3QtbGluZSIsIHNpZ25hdHVyZT0iMWp3UWJJQUttUUU3SndJSDBJRHhpQzFwZWpybE4rVnBIWERXT0ZWeTVOTT0i

#鉴权结果#

如果鉴权失败,则根据不同错误类型返回不同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: 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"
}

#请求参数(创建声纹特征库)#

在调用业务接口时,都需要在 Http Request Body 中配置以下参数,请求数据均为json字符串。 请求参数示例:
{
  "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"
      }
    }
  }
}
参数名类型必传描述
headerobject是用于上传平台参数
header.app_idstring是在平台申请的appid信息
header.statusint是请求状态,取值为:3(一次传完)
parameterobject是用于上传服务特性参数
parameter.s782b4996object是用于上传功能参数
parameter.s782b4996.funcstring是用于指定声纹的具体能力(创建声纹特征库值为createGroup)
parameter.s782b4996.groupIdstring是创建分组的标识,支持字母数字下划线,长度最大为32
parameter.s782b4996.groupNamestring否创建分组的名称,长度最小为0,最大为256
parameter.s782b4996.groupInfostring否创建分组的描述信息,长度最小为0,最大为256
parameter.s782b4996.createGroupResobject是期望返回结果的格式
parameter.s782b4996.createGroupRes.encodingstring是编码格式(固定utf-8)
parameter.s782b4996.createGroupRes.compressstring是压缩格式(固定raw)
parameter.s782b4996.createGroupRes.formatstring是文本格式(固定json)

#返回参数(创建声纹特征库)#

返回参数示例:
{
  "header": {
    "code": 0,
    "message": "success",
    "sid": "ase000e55f5@hu178fca72b160210882"
  },
  "payload": {
    "createGroupRes": {
      "text": "eyJncm91cEl..."
    }
  }
}
text字段Base64解码后示例:
{
  "groupName": "iFLYTEK_examples_groupName",
  "groupId": "iFLYTEK_examples_groupId",
  "groupInfo": "iFLYTEK_examples_groupInfo"
}
参数名类型描述
headerobject用于传递平台参数
header.sidstring本次会话唯一标识id
header.codeint0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。
header.messagestring描述信息
payloadobject数据段,用于携带响应的数据
payload.createGroupResobject响应数据块
payload.createGroupRes.textstring响应数据base64编码
payload.createGroupRes.text字段base64解码后信息如下,请重点关注:
字段类型描述备注
groupIdstring创建分组的唯一标识
groupNamestring创建分组的名称
groupInfostring创建分组的描述信息

#请求参数(添加音频特征)#

在调用业务接口时,都需要在 Http Request Body 中配置以下参数,请求数据均为json字符串。 请求参数示例:
{
  "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..."
    }
  }
}
参数名类型必传描述
headerobject是用于上传平台参数
header.app_idstring是在平台申请的appid信息
header.statusint是请求状态,取值为:3(一次传完)
parameterobject是用于上传服务特性参数
parameter.s782b4996object是用于上传功能参数
parameter.s782b4996.funcstring是用于指定声纹的具体能力(添加音频特征值为createFeature)
parameter.s782b4996.groupIdstring是分组的标识,支持字母数字下划线,长度最大为32
parameter.s782b4996.featureIdstring是特征的标识,长度最小为0,最大为32
parameter.s782b4996.featureInfostring否特征描述信息,长度最小为0,最大为256(建议在特征信息里加入时间戳)
parameter.s782b4996.createFeatureResobject是期望返回结果的格式
parameter.s782b4996.createFeatureRes.encodingstring是编码格式(固定utf-8)
parameter.s782b4996.createFeatureRes.compressstring是压缩格式(固定raw)
parameter.s782b4996.createFeatureRes.formatstring是文本格式(固定json)
payloadobject是用于上传请求数据
payload.resourceobject是用于相关音频相关参数
payload.resource.encodingstring是音频编码(固定lame)
payload.resource.sample_rateint是音频采样率(16000)
payload.resource.channelsint否音频声道数(1单声道)
payload.resource.bit_depthint否音频位深(16)
payload.resource.statusint是音频数据状态(3一次性传完)
payload.resource.audiostring是音频数据base64编码(编码后最小长度:1B 最大长度:4M)

#返回参数(添加音频特征)#

返回参数示例:
{
  "header": {
    "code": 0,
    "message": "success",
    "sid": "ase000ec93e@hu178fd5902750212882"
  },
  "payload": {
    "createFeatureRes": {
      "text": "eyJmZWF0dXJl..."
    }
  }
}
text字段Base64解码后示例:
{
  "featureId": "iFLYTEK_examples_featureId"
}
参数名类型描述
headerobject用于传递平台参数
header.sidstring本次会话唯一标识id
header.codeint0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。
header.messagestring描述信息
payloadobject数据段,用于携带响应的数据
payload.createFeatureResobject响应数据块
payload.createFeatureRes.textstring响应数据base64编码
payload.createFeatureRes.text字段base64解码后信息如下,请重点关注:
字段类型描述备注
featureIdstring特征的唯一标识

#请求参数(更新音频特征)#

在调用业务接口时,都需要在 Http Request Body 中配置以下参数,请求数据均为json字符串。 请求参数示例:
{
  "header": {
    "app_id": "your_app_id",
    "status": 3
  },
  "parameter": {
    "s782b4996": {
      "func": "updateFeature",
      "groupId": "iFLYTEK_examples_groupId",
      "featureId": "iFLYTEK_examples_featureId",
      "featureInfo": "iFLYTEK_examples_featureInfo_update",
      "updateFeatureRes": {
        "encoding": "utf8",
        "compress": "raw",
        "format": "json"
      }
    }
  },
  "payload": {
    "resource": {
      "encoding": "lame",
      "sample_rate": 16000,
      "channels": 1,
      "bit_depth": 16,
      "status": 3,
      "audio": "SUQzBAAAAAAAI1RTU0UAAAAPAAADTGF2ZjU4LjI3Lj..."
    }
  }
}
参数名类型必传描述
headerobject是用于上传平台参数
header.app_idstring是在平台申请的appid信息
header.statusint是请求状态,取值为:3(一次传完)
parameterobject是用于上传服务特性参数
parameter.s782b4996object是用于上传功能参数
parameter.s782b4996.funcstring是用于指定声纹的具体能力(更新音频特征值为updateFeature)
parameter.s782b4996.groupIdstring是此次音频特征所存放的分组标识,支持字母数字下划线,长度最大为32
parameter.s782b4996.featureIdstring否特征的标识,长度最小为0,最大为32
parameter.s782b4996.featureInfostring否特征描述信息,长度最小为0,最大为256(建议在特征信息里加入时间戳)
parameter.s782b4996.coverboolean否更新方式,为true时表示覆盖原有的特征,为false时表示与原有的特征进行合并更新。默认为true
parameter.s782b4996.updateFeatureResobject是期望返回结果的格式
parameter.s782b4996.updateFeatureRes.encodingstring是编码格式(固定utf-8)
parameter.s782b4996.updateFeatureRes.compressstring是压缩格式(固定raw)
parameter.s782b4996.updateFeatureRes.formatstring是文本格式(固定json)
payloadobject是用于上传请求数据
payload.resourceobject是用于相关音频相关参数
payload.resource.encodingstring是音频编码(固定lame)
payload.resource.sample_rateint是音频采样率(16000)
payload.resource.channelsint否音频声道数(1单声道)
payload.resource.bit_depthint否音频位深(16)
payload.resource.statusint是音频数据状态(3一次性传完)
payload.resource.audiostring是音频数据base64编码(编码后最小长度:1B 最大长度:4M)

#返回参数(更新音频特征)#

返回参数示例:
{
  "header": {
    "code": 0,
    "message": "success",
    "sid": "ase000d96a6@hu17a5ad256e70212882"
  },
  "payload": {
    "updateFeatureRes": {
      "status": "3",
      "text": "eyJtc2ciOiJzdWNjZXNzIn0="
    }
  }
}
text字段Base64解码后示例:
{"msg":"success"}
参数名类型描述
headerobject用于传递平台参数
header.sidstring本次会话唯一标识id
header.codeint0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。
header.messagestring描述信息
payloadobject数据段,用于携带响应的数据
payload.updateFeatureResobject响应数据块
payload.updateFeatureRes.textstring响应数据base64编码
payload.updateFeatureRes.text字段base64解码后信息如下,请重点关注:
字段类型描述备注
msgstring更新信息success代表更新成功

#请求参数(查询特征列表)#

注:查询结果可能受限制无法展示全部特征。
在调用业务接口时,都需要在 Http Request Body 中配置以下参数,请求数据均为json字符串。
请求参数示例:
{
  "header": {
    "app_id": "your_app_id",
    "status": 3
  },
  "parameter": {
    "s782b4996": {
      "func": "queryFeatureList",
      "groupId": "iFLYTEK_examples_groupId",
      "queryFeatureListRes": {
        "encoding": "utf8",
        "compress": "raw",
        "format": "json"
      }
    }
  }
}
参数名类型必传描述
headerobject是用于上传平台参数
header.app_idstring是在平台申请的appid信息
header.statusint是请求状态,取值为:3(一次传完)
parameterobject是用于上传服务特性参数
parameter.s782b4996object是用于上传功能参数
parameter.s782b4996.funcstring是用于指定声纹的具体能力(查询特征列表值为queryFeatureList)
parameter.s782b4996.groupIdstring是查询特征所在的分组标识,支持字母数字下划线,长度最大为32
parameter.s782b4996.queryFeatureListResobject是期望返回结果的格式
parameter.s782b4996.queryFeatureListRes.encodingstring是编码格式(固定utf-8)
parameter.s782b4996.queryFeatureListRes.compressstring是压缩格式(固定raw)
parameter.s782b4996.queryFeatureListRes.formatstring是文本格式(固定json)

#返回参数(查询特征列表)#

返回参数示例:
{
  "header": {
    "code": 0,
    "message": "success",
    "sid": "ase000eebfc@hu178fd7c11f20212882"
  },
  "payload": {
    "queryFeatureListRes": {
      "text": "W3siZmVhdHVy..."
    }
  }
}
text字段Base64解码后示例:
[
  {
    "featureInfo": "iFLYTEK_examples_featureInfo",
    "featureId": "iFLYTEK_examples_featureId"
  }
]
参数名类型描述
headerobject用于传递平台参数
header.codeint0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。
header.messagestring描述信息
header.sidstring本次会话唯一标识id
payloadobject数据段,用于携带响应的数据
payload.queryFeatureListResobject响应数据块
payload.queryFeatureListRes.textstring响应数据base64编码
payload.queryFeatureListRes.text字段base64解码后信息如下,请重点关注:
字段类型描述备注
featureInfostring特征描述(建议创建时加时间戳,方便查找对应音频信息)
featureIdstring特征标识

#请求参数(特征比对1:1)#

在调用业务接口时,都需要在 Http Request Body 中配置以下参数,请求数据均为json字符串。 请求参数示例:
{
  "header": {
    "app_id": "your_app_id",
    "status": 3
  },
  "parameter": {
    "s782b4996": {
      "func": "searchScoreFea",
      "groupId": "iFLYTEK_examples_groupId",
      "dstFeatureId": "iFLYTEK_examples_featureId",
      "searchScoreFeaRes": {
        "encoding": "utf8",
        "compress": "raw",
        "format": "json"
      }
    }
  },
  "payload": {
    "resource": {
      "encoding": "lame",
      "sample_rate": 16000,
      "channels": 1,
      "bit_depth": 16,
      "status": 3,
      "audio": "SUQzBAAAAAAAI1RTU0UAA..."
    }
  }
}
参数名类型必传描述
headerobject是用于上传平台参数
header.app_idstring是在平台申请的appid信息
header.statusint是请求状态,取值为:3(一次传完)
parameterobject是用于上传服务特性参数
parameter.s782b4996object是用于上传功能参数
parameter.s782b4996.funcstring是用于指定声纹的具体能力(特征比对1:1值为searchScoreFea)
parameter.s782b4996.groupIdstring是需要比对特征所存放的分组标识,支持字母数字下划线,长度最大为32
parameter.s782b4996.dstFeatureIdstring是需要比对的特征的标识,长度最小为0,最大为32
parameter.s782b4996.searchScoreFeaResobject是期望返回结果的格式
parameter.s782b4996.searchScoreFeaRes.encodingstring是编码格式(固定utf-8)
parameter.s782b4996.searchScoreFeaRes.compressstring是压缩格式(固定raw)
parameter.s782b4996.searchScoreFeaRes.formatstring是文本格式(固定json)
payloadobject是用于上传请求数据
payload.resourceobject是用于相关音频相关参数
payload.resource.encodingstring是音频编码(固定lame)
payload.resource.sample_rateint是音频采样率(16000)
payload.resource.channelsint否音频声道数(1单声道)
payload.resource.bit_depthint否音频位深(16)
payload.resource.statusint是音频数据状态(3一次性传完)
payload.resource.audiostring是音频数据base64编码(编码后最小长度:1B 最大长度:4M)

#返回参数(特征比对1:1)#

返回参数示例:
{
  "header": {
    "code": 0,
    "message": "success",
    "sid": "ase000e1142@hu178fd98935d0212882"
  },
  "payload": {
    "searchScoreFeaRes": {
      "text": "eyJhZ2UiOiJja..."
    }
  }
}
text字段Base64解码后示例:
{
  "score": 1,
  "featureInfo": "iFLYTEK_examples_featureInfo",
  "featureId": "iFLYTEK_examples_featureId"
}
参数名类型描述
headerobject用于传递平台参数
header.sidstring本次会话唯一标识id
header.codeint0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。
header.messagestring描述信息
payloadobject数据段,用于携带响应的数据
payload.searchScoreFeaResobject响应数据块
payload.searchScoreFeaRes.textstring响应数据base64编码
payload.searchScoreFeaRes.text字段base64解码后信息如下,请重点关注:
字段类型描述
scorefloat正常相似度得分0~1,精确到小数点后两位。(相似度范围-1到1)
featureInfostring目标特征的描述信息
featureIdstring目标特征的唯一标识

#请求参数(特征比对1:N)#

在调用业务接口时,都需要在 Http Request Body 中配置以下参数,请求数据均为json字符串。 请求参数示例:
{
  "header": {
    "app_id": "your_app_id",
    "status": 3
  },
  "parameter": {
    "s782b4996": {
      "func": "searchFea",
      "groupId": "iFLYTEK_examples_groupId",
      "topK": 2,
      "searchFeaRes": {
        "encoding": "utf8",
        "compress": "raw",
        "format": "json"
      }
    }
  },
  "payload": {
    "resource": {
      "encoding": "lame",
      "sample_rate": 16000,
      "channels": 1,
      "bit_depth": 16,
      "status": 3,
      "audio": "SUQzBAAAAAAAI1RTU0UAAAAPAAA..."
    }
  }
}
参数名类型必传描述
headerobject是用于上传平台参数
header.app_idstring是在平台申请的appid信息
header.statusint是请求状态,取值为:3(一次传完)
parameterobject是用于上传服务特性参数
parameter.s782b4996object是用于上传功能参数
parameter.s782b4996.funcstring是用于指定声纹的具体能力(特征比对1:N值为searchFea)
parameter.s782b4996.groupIdstring是指定分组进行比对,支持字母数字下划线,长度最大为32
parameter.s782b4996.topKint是期望返回的特征数目,最大为10(要有足够的特征数量)
parameter.s782b4996.searchFeaResobject是期望返回结果的格式
parameter.s782b4996.searchFeaRes.encodingstring是编码格式(固定utf-8)
parameter.s782b4996.searchFeaRes.compressstring是压缩格式(固定raw)
parameter.s782b4996.searchFeaRes.formatstring是文本格式(固定json)
payloadobject是用于上传请求数据
payload.resourceobject是用于相关音频相关参数
payload.resource.encodingstring是音频编码(固定lame)
payload.resource.sample_rateint是音频采样率(16000)
payload.resource.channelsint否音频声道数(1单声道)
payload.resource.bit_depthint否音频位深(16)
payload.resource.statusint是音频数据状态(3一次性传完)
payload.resource.audiostring是音频数据base64编码(编码后最小长度:1B 最大长度:4M)

#返回参数(特征比对1:N)#

返回参数示例:
{
  "header": {
    "code": 0,
    "message": "success",
    "sid": "ase000e3672@hu178fdb6c69d0210882"
  },
  "payload": {
    "searchFeaRes": {
      "text": "eyJhZ2UiOiJ5b..."
    }
  }
}
text字段Base64解码后示例:
{
  "scoreList": [
    {
      "score": 1,
      "featureInfo": "iFLYTEK_examples_featureInfo1",
      "featureId": "iFLYTEK_examples_featureId1"
    },
    {
      "score": 0.85,
      "featureInfo": "iFLYTEK_examples_featureInfo",
      "featureId": "iFLYTEK_examples_featureId"
    }
  ]
}
参数名类型描述
headerobject用于传递平台参数
header.sidstring本次会话唯一标识id
header.codeint0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。
header.messagestring描述信息
payloadobject数据段,用于携带响应的数据
payload.searchFeaResobject响应数据块
payload.searchFeaRes.textstring响应数据base64编码
payload.searchFeaRes.text字段base64解码后信息如下,请重点关注:
字段类型描述
scoreListarray特征比对结果
scoreList[n].scorefloat正常相似度得分0~1,精确到小数点后两位。(相似度范围-1到1)
scoreList[n].featureInfostring目标特征的描述信息
scoreList[n].featureIdstring目标特征的唯一标识

#请求参数(删除指定特征)#

在调用业务接口时,都需要在 Http Request Body 中配置以下参数,请求数据均为json字符串。 请求参数示例:
{
  "header": {
    "app_id": "your_app_id",
    "status": 3
  },
  "parameter": {
    "s782b4996": {
      "func": "deleteFeature",
      "groupId": "iFLYTEK_examples_groupId",
      "featureId": "iFLYTEK_examples_featureId",
      "deleteFeatureRes": {
        "encoding": "utf8",
        "compress": "raw",
        "format": "json"
      }
    }
  }
}
参数名类型必传描述
headerobject是用于上传平台参数
header.app_idstring是在平台申请的appid信息
header.statusint是请求状态,取值为:3(一次传完)
parameterobject是用于上传服务特性参数
parameter.s782b4996object是用于上传功能参数
parameter.s782b4996.funcstring是用于指定声纹的具体能力(删除指定特征值为deleteFeatureRes)
parameter.s782b4996.groupIdstring是删除特征所在的分组标识,支持字母数字下划线,长度最大为32
parameter.s782b4996.featureIdstring是所需要删除的特征标识,长度最小为1,最大为32
parameter.s782b4996.deleteFeatureResobject是期望返回结果的格式
parameter.s782b4996.deleteFeatureRes.encodingstring是编码格式(固定utf-8)
parameter.s782b4996.deleteFeatureRes.compressstring是压缩格式(固定raw)
parameter.s782b4996.deleteFeatureRes.formatstring是文本格式(固定json)

#返回参数(删除指定特征)#

返回参数示例:
{
  "header": {
    "code": 0,
    "message": "success",
    "sid": "ase000e75d9@hu178fdf66e290210882"
  },
  "payload": {
    "deleteFeatureRes": {
      "text": "eyJtc2ciOi..."
    }
  }
}
text字段Base64解码后示例:
{
  "msg": "success"
}
headerobject用于传递平台参数
header.codeint0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。
header.messagestring描述信息
header.sidstring本次会话唯一标识id
payloadobject数据段,用于携带响应的数据
payload.deleteFeatureResobject响应数据块
payload.deleteFeatureRes.textstring响应数据base64编码
payload.deleteFeatureRes.text字段base64解码后信息如下,请重点关注:
字段类型描述
msgstring删除结果(删除成功时返回success)

#请求参数(删除声纹特征库)#

在调用业务接口时,都需要在 Http Request Body 中配置以下参数,请求数据均为json字符串。 请求参数示例:
{
  "header": {
    "app_id": "your_app_id",
    "status": 3
  },
  "parameter": {
    "s782b4996": {
      "func": "deleteGroup",
      "groupId": "iFLYTEK_examples_groupId",
      "deleteGroupRes": {
        "encoding": "utf8",
        "compress": "raw",
        "format": "json"
      }
    }
  }
}
参数名类型必传描述
headerobject是用于上传平台参数
header.app_idstring是在平台申请的appid信息
header.statusint是请求状态,取值为:3(一次传完)
parameterobject是用于上传服务特性参数
parameter.s782b4996object是用于上传功能参数
parameter.s782b4996.funcstring是用于指定声纹的具体能力(删除声纹特征库值为deleteGroup)
parameter.s782b4996.groupIdstring是删除分组的标识,支持字母数字下划线,长度最大为32
parameter.s782b4996.deleteGroupResobject是期望返回结果的格式
parameter.s782b4996.deleteGroupRes.encodingstring是编码格式(固定utf-8)
parameter.s782b4996.deleteGroupRes.compressstring是压缩格式(固定raw)
parameter.s782b4996.deleteGroupRes.formatstring是文本格式(固定json)

#返回参数(删除声纹特征库)#

返回参数示例:
{
  "header": {
    "code": 0,
    "message": "success",
    "sid": "ase000dcbc0@hu17a5ae64ab30212882"
  },
  "payload": {
    "deleteGroupRes": {
      "status": "3",
      "text": "eyJtc2ciOiJzdWNjZXNzIn0="
    }
  }
}
text字段Base64解码后示例:
{"msg":"success"}
参数名类型描述
headerobject用于传递平台参数
header.sidstring本次会话唯一标识id
header.codeint0表示会话调用成功(并不一定表示服务调用成功,服务是否调用成功以text字段为准) 其它表示会话调用异常,详情请参考错误码。
header.messagestring描述信息
payloadobject数据段,用于携带响应的数据
payload.deleteGroupResobject响应数据块
payload.deleteGroupRes.textstring响应数据base64编码
payload.deleteGroupRes.text字段base64解码后信息如下,请重点关注:
字段类型描述备注
msgstring删除特征库是否成功success表示删除成功

#错误码#

备注:如出现下述列表中没有的错误码,可到 这里 查询。
错误码错误描述说明处理方法
10009input invalid data输入数据非法检查输入的数据
10160parse request json error请求数据格式非法检查请求数据是否是合法的json
10161parse base64 string errorbase64解码失败检查发送的数据是否使用base64编码了
10313invalid appidappid和apikey不匹配检查appid是否合法
23005failed to create feature detail创建特征失败检查是否创建声纹特征库
23006failed to delete feature detail删除特征失败请查看删除的特征ID是否已经删除

#调用示例#

声纹识别demo java语言
声纹识别demo python语言
注: 其他开发语言请参照 接口调用流程 进行开发,也欢迎热心的开发者到 讯飞开放平台社区 分享你们的demo。

#常见问题#

#声纹识别1:1与1:N有什么区别?#

答:1:1模式主要做身份验证,主要证明你是你,主要应用场景为实名制场景(例如声纹解锁、声纹支付等)。而1:N模式则是验证你是谁,应用场景有办公考勤、会议签到等。

#声纹的识别是否需要读固定的文本,文本有什么限制?#

答:不需要读固定的文本,文本没有限制。

#声纹识别得分在什么范围可以判定验证通过?#

答:建议的参考得分范围为0.6-1可以判定验证通过,具体可以结合应用场景的安全性要求做进一步判断。

#不同appid可以创建名称相同的声纹特征库吗?#

答:可以,每个appid的声纹特征库是相互独立的。
上一页
性别能力识别 API
下一页
声纹识别 API
Built with