接口说明
接口说明
#接口Demo
目前仅提供部分开发语言的demo,其他语言请参照下方接口文档进行开发。
也欢迎热心的开发者到 讯飞开放平台社区 分享你们的demo。
#接口要求
内容 | 说明 |
---|---|
传输方式 | http[s] (为提高安全性,强烈推荐https) |
请求地址 | http[s]: //rest-api.xfyun.cn/v2/itr 注:服务器IP不固定,为保证您的接口稳定,请勿通过指定IP的方式调用接口,使用域名方式调用 |
请求行 | POST /v2/itr HTTP/1.1 |
接口鉴权 | 签名机制,详情请参照下方鉴权认证 |
字符编码 | UTF-8 |
响应格式 | 统一采用JSON格式 |
开发语言 | 任意,只要可以向讯飞云服务发起HTTP请求的均可 |
适用范围 | 任意操作系统,但因不支持跨域不适用于浏览器 |
图片属性 | 最短边至少15px,最长边最大4096px,支持文字与水平轴小于±15°夹角偏转 |
图片格式 | jpg/png/bmp |
图片大小 | base64编码后大小不超过4M |
#接口调用流程
· 将请求参数以及图片数据放在Http Request Body中,以POST表单的形式提交,详见下方 请求参数 。
· 向服务器端发送Http请求后,接收服务器端的返回结果。
#白名单
在调用该业务接口时
#鉴权认证
#鉴权方法
Header示例:
Content-Type:application/json
Accept:application/json,version=1.0
Host:rest-api.xfyun.cn
Date:Mon, 18 Mar 2019 08:32:07 GMT
Digest:SHA-256=MGNjNThlMTU3ZWNmYjU4YTlhNTAwNDI5NWE4NTBmNWM5ZTMwMmM5OGZiNzE2ODY4ZjM2ZTQxYmNjMzkzZjIwYQ==
Authorization:api_key="your_key", algorithm="hmac-sha256", headers="host date request-line digest", signature="$signature"
参数 | 类型 | 必须 | 说明 | 示例 |
---|---|---|---|---|
Host | string | 是 | 请求主机 | rest-api.xfyun.cn |
Date | string | 是 | 当前时间戳,RFC1123格式("EEE, dd MMM yyyy HH:mm:ss z") | Tue, 30 Jul 2019 07:51:27 GMT |
Digest | string | 是 | 加密请求body SHA-256=Base64(SHA256(请求body)) body请参考下方公共请求参数 | SHA-256=AmSJeAtB.... |
Authorization | string | 是 | 使用base64编码的签名相关信息(签名基于hamc-sha256计算) | 参考下方签名详细生成规则 |
服务端会对Date进行时钟偏移检查,最大允许300秒的偏差,超出偏差的请求都将被拒绝。
Authorization: api_key="your_key", algorithm="hmac-sha256", headers="host date request-line digest", signature="$signature"
示例:api_key="apikeyXXXXXXXXXXXXXXXXXXXXXXXXXX", algorithm="hmac-sha256", headers="host date request-line digest", signature="RhJ/0FO+Df2zuTQcseN1jxRoonKeuKi0wXRByQUgIA0="
algorithm 是加密算法(仅支持hmac-sha256),headers 是参与签名的参数。
signature 是使用加密算法对参与签名的参数签名后并使用base64编码的字符串,详见下方。
拼接的格式为(\n为换行符,’:’后面有一个空格): host: date\ndigest
请求的body为:{"common":{"app_id":"5dXXXXXX"},"business":{"ent":"teach-photo-print","aue":"raw"},"data":{"image":"/9j/4AAQSkZJRgABAQAAAQABAA...."}}
则signature生成步骤如下:
digest: SHA-256=Base64(SHA256(请求body))
例:digest: SHA-256=AmSJeAtBmL+v9F4RZfeKkubQP2YIuVDkH76yFwyO/Sg=
host: rest-api.xfyun.cn
date: Tue, 30 Jul 2019 07:51:27 GMT
POST /v2/itr HTTP/1.1
digest: SHA-256=AmSJeAtBmL+v9F4RZfeKkubQP2YIuVDkH76yFwyO/Sg=
apiSecret在控制台的公式识别页面可查看,这里以apisecretXXXXXXXXXXXXXXXXXXXXXXX为例
signature_sha=hmac-sha256(signature_origin,$apiSecret)
signature=base64(signature_sha)
例:RhJ/0FO+Df2zuTQcseN1jxRoonKeuKi0wXRByQUgIA0=
#鉴权示例(golang)
#鉴权结果
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分钟以上会报此错误 |
403 | IP白名单校验失败 | {"message":"Your IP address is not allowed"} | 可在控制台关闭IP白名单,或者检查IP白名单设置的IP地址是否为本机外网IP地址 |
HTTP/1.1 401 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"
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
region.list[index].coord | dict | 识别区域形状和位置信息 |
region.list[index].coord.x | int | 识别区域矩形左上角点x坐标 以上传图片的左上角为原点,横向为x轴(向右为正),纵向为y轴(向下为正) |
region.list[index].coord.y | int | 识别区域矩形左上角点y坐标 以上传图片的左上角为原点,横向为x轴(向右为正),纵向为y轴(向下为正) |
region.list[index].coord.width | int | 识别区域矩形宽度 |
region.list[index].coord.height | int | 识别区域矩形高度 |
公式题型
No. | 题型名称 | 题型示例 |
---|---|---|
1 | 平面直角坐标系 | ![]() |
2 | 一元二次方程 | ![]() |
3 | 概率初步cz | ![]() |
4 | 函数及其图像 | ![]() |
5 | 解直角三角形 | ![]() |
6 | 平面几何 | |
7 | 投影与视图 | ![]() |
8 | 代数 | |
9 | 实数与二次根 | ![]() |
10 | 三角形 | ![]() |
11 | 相似形 | |
12 | 分式 | |
13 | 统计初步(初中) | ![]() |
14 | 圆锥曲线方程 | ![]() |
15 | 直线和圆方程 | ![]() |
16 | 直线和平面 | ![]() |
17 | 三角函数 | ![]() |
18 | 复数 | ![]() |
19 | 概率初步gz | ![]() |
20 | 函数和投影 | ![]() |
21 | 推理和证明 | ![]() |
22 |