我们的API将应用实体(项目、作业、设置)视为可以检索、创建、修改和删除的资源。
每个HTTP方法代表一个操作:
-
GET
检索资源,永远不改变资源
-
POST
创建资源。POST也用于不适合四种操作或具有长或复杂输入的操作,例如搜索翻译记忆或创建作业。
-
PUT
更新资源。请注意,整个实体及其所有字段都是必需的,而不仅仅是那些更改的字段;不包括它意味着应该设置为null。
-
DELETE
删除资源。
重要
输入和输出数据通常采用JSON格式,UTF-8编码。对于请求体内容类型,使用application/octet-stream或multipart/form-data。
实体在可能的情况下使用扁平结构以保持良好的响应时间。在回答中,不是包含整个子对象,而是包含包含ID、UID和其他几个属性的引用。期望使用IDReference或UidReference对象来引用相关实体。
所有响应列表都是分页的。使用参数 pageNumber 和 pageSize 来检索请求的数据。最大页面大小为 50。
文档
OpenAPI 3.0 用于 API 文档。Swagger 代码生成器 推荐用于客户开发。
API 示例
获取所有翻译记忆库的列表
GET
/web/api2/v1/transMemories
Response
200
{
"pageNumber": 0,
"content": [
{
"internalId": 1,
"createdBy": {
"userName": "admin",
"id": "3",
"firstName": "Jan",
"lastName": "Janocko",
"role": "ADMIN",
"email": "jan.janocko@phrase.com"
},
"client": null,
"note": "在 TM 中不需要使用,"
"dateCreated": "2018-01-09T14:07:46+0000",
"id": "1",
"targetLangs": [
"es",
"it"
],
"subDomain": null,
"businessUnit": {
"id": "1",
"name": "第一个 BU"
},
"sourceLang": "en",
"domain": null,
"name": "我的新翻译记忆库"
}
],
"numberOfElements": 1,
"totalElements": 1,
"pageSize": 50,
"totalPages": 1
}
创建新的翻译记忆库
POST
/web/api2/v1/transMemories
{{
"name": "我的新翻译记忆库,"
"sourceLang": "en",
"targetLangs": [
"es", "it-IT"
],
"businessUnit": {
"id": "1"
},
"note": "在 TM 中不需要使用"
}
Response
201
{
"internalId": 1,
"createdBy": {
"userName": "admin",
"id": "3",
"firstName": "J",
"lastName": "Jan",
"role": "ADMIN",
"email": "jan.j@phrase.com"
},
"client": null,
"note": "在 TM 中不需要使用,"
"dateCreated": "2018-01-09T14:07:46+0000",
"id": "1",
"targetLangs": [
"es",
"it"
],
"subDomain": null,
"businessUnit": {
"id": "1",
"name": "第一个 BU"
},
"sourceLang": "en",
"domain": null,
"name": "我的新翻译记忆库"
}
创建作业时添加文件
将此文件作为二进制附件添加到请求的主体中。确保 Phrase 和 Content-Disposition 头正确插入。
来自 Postman 的示例 PHP:
<?php
$request = new HttpRequest();
$request->setUrl('https://cloud.memsource.com/web/api2/v1/projects/%7BUID%20of%20your%20project%7D/jobs');
$request->setMethod(HTTP_METH_POST);
$request->setQueryData(array(
'token' => '您的令牌在这里'
));
$request->setHeaders(array(
'postman-token' => 'ABC',
'cache-control' => 'no-cache',
'content-disposition' => 'filename*=UTF-8''Sample.txt',
'memsource' => '{\\"targetLangs\\":[\\"de\\",\\"fr\\",\\"es\\"],\\"callbackUrl\\":\\"https://my-shiny-service.com/consumeCallback\\",\\"importSettings\\":{\\"uid\\":\\"WF0T1SfSHxII09yKr0dZh9\\"}}'
));
尝试 {
$response = $request->send();
echo $response->getBody();
} catch (HttpException $ex) {
echo $ex;
}
错误处理
如果处理 API 请求时出现问题,将返回以下 JSON 结构。错误代码将始终存在;详细描述可能为 null。
{ "errorCode": "InvalidArguments",
"errorDescription": "缺少类型为 \"string\" 的必需参数 \"password\"。"
}
可以通过读取 HTTP 状态 响应代码 来检测错误响应。如果发生错误,它将永远不会设置为 2xx。状态代码为 400 错误请求,401 或 403 表示身份验证或授权问题。
报告问题
在向技术支持报告问题时,请在报告中包含以下内容:
-
API端点
-
请求
-
时间(和时区)
-
响应
-
响应的短语-动作-ID