0

我正在编写一个符合https://jsonapi.org/format/标准的 api 规范。我无法确定要在以下场景中实现的正确 uri 格式。

概述:

公司库存系统包含产品和价格信息。一种产品有多种价格。库存系统通过 API 将数据推送到本地系统,但使用库存系统主键。本地系统应将提供的数据捕获到 API 中,并在本地数据库中更新或创建价格记录

例如:

发布/产品/..... ?? 或发布/产品/

{
   "data":{
       "externalId":"EIR-32432",
       "externalPriceId":xxx,
       "price":"xxx.xx",
       "currency":"USD"
   }
}
4

2 回答 2

1

您必须向代表该资源集合的 URL 发送POST请求,以在 JSON:API 规范中创建资源:

可以通过向代表资源集合的 URL 发送 POST 请求来创建资源。请求必须包含一个资源对象作为主要数据。资源对象必须至少包含一个类型成员。

规范本身与 URL 命名无关,但在所有示例中都使用了多元化的资源类型。如果您遵循相同的约定,则创建产品的请求应该是POST /products.

如上面引用所述,请求必须包含一个资源对象。您问题中的示例不是有效的资源对​​象,因为它缺少 atype并且属性不在attributes键下。创建产品的有效资源对象如下所示:

{
    "data":{
        "type": "products",
        "attributes": {
            "externalId": "EIR-32432",
            "externalPriceId": "xxx",
            "price": "xxx.xx",
            "currency": "USD"
        }
    }
}

另请注意,关系不应显示为属性:

尽管只有一个外键(例如 author_id)通常与要在资源对象中表示的其他信息一起存储在内部,但这些键不应显示为属性。

从您的示例中不太清楚,externalId关系externalPriceId是否在您的 API 范围内。

请在规范本身中找到有关在 JSON:API 中创建资源的更多详细信息:https ://jsonapi.org/format/#crud-creating它还附带了一个示例。

于 2019-03-27T13:00:54.073 回答
-1

您可以在此处检查 URI 的一些命名:https ://restfulapi.net/resource-naming/

于 2019-03-26T01:28:02.677 回答