机器翻译niutrans API
开发环境
开发环境
POST
http[s]: //ntrans.xfyun.cn/v2/ots
接口说明
注: 原老版本 机器翻译1.0( http://openapi.openspeech.cn/webapi/its.do )的老用户,烦 请尽快使用最新的机器翻译2.0接口。机器翻译1.0我们会在近几个月内渐渐停止维护,为了您的服务稳定,请马上切换。
机器翻译2.0 demo python3语言
机器翻译2.0 demo java语言
机器翻译2.0 demo nodejs语言
机器翻译2.0 demo php语言
机器翻译2.0 demo go语言
内容 | 说明 |
---|---|
传输方式 | http[s] (为提高安全性,强烈推荐https) |
请求地址 | http[s]: //ntrans.xfyun.cn/v2/ots 注:服务器IP不固定,为保证您的接口稳定,请勿通过指定IP的方式调用接口,使用域名方式调用 |
请求行 | POST /v2/ots HTTP/1.1 |
接口鉴权 | 签名机制,详情请参照下方鉴权说明 |
字符编码 | UTF-8 |
响应格式 | 统一采用JSON格式 |
开发语言 | 任意,只要可以向讯飞云服务发起HTTP请求的均可 |
适用范围 | 任意操作系统,但因不支持跨域不适用于浏览器,请在后端调用接口 |
文本长度 | 单次文本长度不得超过5000字符 一个汉字、英文字母、标点符号等,均计为一个字符 |
文本大小 | base64编码后大小不得超过 20000 bytes(约5000个汉字) |
文本语言 | 支持100多种语种,详细请参照 语种列表 |
#白名单
在调用该业务接口时
#鉴权说明
Header示例:
Content-Type:application/json
Accept:application/json,version=1.0
Host:ntrans.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 | 是 | 请求主机 | ntrans.xfyun.cn |
Date | string | 是 | 当前时间戳,RFC1123格式("EEE, dd MMM yyyy HH:mm:ss z" ) | Tue, 30 Jul 2019 08:39:29 GMT |
Digest | string | 是 | 加密请求body SHA-256=Base64(SHA256(请求body)) body请参考下方请求参数 | SHA-256=MGNjNThl.... |
Authorization | string | 是 | 使用base64编码的签名相关信息(签名基于hamc-sha256计算) | 参考下方 |
服务端会对Date进行时钟偏移检查,最大允许300秒的偏差,超出偏差的请求都将被拒绝。
Authorization: api_key="your_key", algorithm="hmac-sha256", headers="host date request-line digest", signature="$signature"
示例:Authorization: api_key="apikeyXXXXXXXXXXXXXXXXXXXXXXXXXX", algorithm="hmac-sha256", headers="host date request-line digest", signature="XwMFU8JKrxdDeVLpplLua9Rjcv/IlaS5tWbmXg0eM80="
algorithm 是加密算法(仅支持hmac-sha256),headers 是参与签名的参数。
signature 是使用加密算法对参与签名的参数签名后并使用base64编码的字符串,详见下方。
拼接的格式为(\n为换行符,’:’后面有一个空格):
host: $host\ndate: $date\n$request-line\ndigest: $digest
请求的url为:https://ntrans.xfyun.cn/v2/ots
请求的body为:
{
"common": {
"app_id": "5dXXXXXX"
},
"business": {
"from": "cn",
"to": "en"
},
"data": {
"text": "5Lit5Y2O5Lq65rCR5YWx5ZKM5Zu95LqOMTk0OeW5tOaIkOeriw=="
}
}
digest: SHA-256=Base64(SHA256(请求body))
例:digest: SHA-256=zUoH6Uf3m5KWEV4aaH7nNFQRCpJG5NWh5RUKa41mGRo=
host: ntrans.xfyun.cn
date: Tue, 30 Jul 2019 08:39:29 GMT
POST /v2/ots HTTP/1.1
digest: SHA-256=zUoH6Uf3m5KWEV4aaH7nNFQRCpJG5NWh5RUKa41mGRo=
signature_sha=hmac-sha256(signature_origin,$apiSecret)
signature=base64(signature_sha)
例:wsjJ7v3nlsQcxLoeyB81MAGEN7NS31lxgw6z9VzHGwg=
#鉴权示例(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"
}
语种列表
语种 | 参数 | 语种 | 参数 | 语种 | 参数 |
---|---|---|---|---|---|
中文(简体) | cn | 海地克里奥尔语 | ht | 普什图语 | ps |
中文(繁体) | cht | 匈牙利语 | hu | 隆迪语 | rn |
英语 | en | 亚美尼亚语 | hy | 罗马尼亚语 | ro |
日语 | ja | 印尼语 | id | 卢旺达语 | rw |
韩语 | ko | 伊博语 | ig | 信德语 | sd |
俄语 | ru | 冰岛语 | is | 桑戈语 | sg |
法语 | fr | 意大利语 | it | 僧伽罗语 | si |
西班牙语 | es | 印尼爪哇语 | jv | 斯洛伐克语 | sk |
阿拉伯语 | ar | 格鲁吉亚语 | jy | 斯洛文尼亚语 | sl |
葡萄牙语 | pt | 哈萨克语 | ka | 萨摩亚语 | sm |
南非荷兰语 | af | 凯克其语 | kek | 修纳语 | sn |
阿姆哈拉语 | am | 刚果语 | kg | 索马里语 | so |
阿塞拜疆语 | az | 哈萨克语(西里尔) | kk | 阿尔巴尼亚语 | sq |
巴什基 尔语 | ba | 高棉语 | km | 塞尔维亚语 | sr |
白俄罗斯语 | be | 卡纳达语 | kn | 塞索托语 | st |
别姆巴语 | bem | 库尔德语 | ku | 印尼巽他语 | su |
保加利亚语 | bg | 吉尔吉斯语 | ky | 瑞典语 | sv |
比斯拉马语 | bi | 拉丁语 | la | 斯瓦希里语 | sw |
孟加拉语 | bn | 卢森堡语 | lb | 泰米尔语 | ta |
波斯尼亚语 | bs | 卢干达语 | lg | 泰卢固语 | te |
加泰罗尼亚语 | ca | 林加拉语 | ln | 塔吉克语 | tg |
宿务语 | ceb | 老挝语 | lo | 茨瓦纳语 | tn |
科西嘉语 | co | 立陶宛语 | lt | 泰语 | th |
塞舌尔克里奥尔语 | crs | 拉脱维亚语 | lv | 藏语 | ti |
捷克语 | cs | 马尔加什语 | mg | 提格雷语 | tig |
威尔士语 | cy | 马里语 | mhr | 土库曼语 | tk |
丹麦语 | da | 毛利语 | mi | 汤加语 | to |
德语 | de | 马其顿语 | mk | 巴布亚皮钦语 | tpi |
埃维语 | ee | 马拉雅拉姆语 | ml | 土耳其语 | tr |
希腊语 | el | 蒙古语(西里尔) | mn | 聪加语 | ts |
世界语 | eo | 马拉地语 | mr | 鞑靼语 | tt |
爱沙尼亚语 | et | 山地马里语 | mrj | 契维语 | tw |
巴斯克语 | eu | 马来语 | ms | 塔希提语 | ty |
波斯语 | fa | 马耳他语 | mt | 乌德穆尔特语 | udm |
芬兰语 | fi | 白苗文 | mww | 乌克兰语 | uk |
菲律宾语 | fil | 缅甸语 | my | 乌尔都语 | ur |
斐济语 | fj | 博克马尔语 | nb | 维吾尔语 | uy |
弗里西语 | fy | 尼泊尔语 | ne | 乌兹别克语 | uz |
爱尔兰语 | ga | 荷兰语 | nl | 越南语 | vi |
苏格兰盖尔语 | gd | 挪威语 | no | 瓦瑞语 | war |
加利西亚 | gl | 齐切瓦语 | ny | 南非科萨语 | xh |
古吉拉特语 | gu | 奥罗莫语 | om | 意第绪语 | yi |
豪萨语 | ha | 奥赛梯语 | os | 约鲁巴语 | yo |
夏威夷语 | haw | 克雷塔罗奥托米语 | otq | 尤卡坦玛雅语 | yua |
希伯来语 | he | 旁遮普语 | pa | 广东话 | yue |
印地语 | hi | 帕皮阿门托语 | pap | 南非祖鲁语 | zu |
克罗地亚语 | hr | 波兰语 | pl |
#常见问题
#机器翻译的主要功能是什么?
答:支持文本到文本的机器翻译。
#机器翻译支持哪些语种?
答:目前支持包括英、日、韩、法、西、俄等100多种语言,详细的语种可见语种列表。