- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 Swagger 来实现我的 ASP.NET Core API,并使用 Swashbuckle,它在单独的文档中描述了我的 API,并为所有这些信息提供了一个漂亮的 UI。
使用 HATEOAS、HAL 或 JSON-LD 等与 Swagger 结合修改文档本身是否有任何优势?
Here是某人将 Swagger 与 HAL 结合使用的示例。
最佳答案
就像 sampada 所说的那样 - swagger 和 HATEOAS - 为您的 api 的不同维度增加更多值(value)。
Swagger 将为开发生命周期增加值(value),使您的 api 在开发时更易于理解和浏览。
HATEOAS 在客户端使用时将为您的 API 增加值(value)。HATEOAS 提供的链接使您可以链接 api 的不同部分(即:资源),而无需在应用程序客户端代码中对这些链接进行硬编码。
假设您有一份契约(Contract)以及一些与之相关的文件。对此进行建模的一种非常常见的方法是使用两种资源:
要将这两者链接在一起,您可以在两个包含相关资源数组的资源模型中添加字段。此外,您还必须在客户端应用程序中实现这些隐式知识。这样,随着时间的推移,您将给您的资源表示添加困惑,并用有关与其他对象的关系的信息污染它。
这就是 HATEOAS 发挥作用的地方,它既可以将这些关系信息从业务对象中移出,又可以提供统一的方式来处理这些关系。这两个资源业务对象现在都将包含一个标准化 header 或值字段,其中包含有关当前资源的所有关系的信息。例如。现在,一个契约(Contract)资源将具有 3 个带有 rel-attribute“document”的链接,链接到相应的文档资源,以及 1 个带有 rel-attribute“order”的链接,链接到该契约(Contract)所产生的订单。
据我所知JSON-LD用于标准化不同API的词汇,使它们更容易并排使用。有些人可能会使用firstName和lastName作为Person对象的属性,而另一些人可能会使用名为givenName和familyName的属性。使用 JSON-LD,您可以将两个对象映射到一个通用名称。您可以考虑查看此链接:DZone - Json-LD
关于json - 您应该将 Swagger 与 HATEOAS/HAL/JSON-LD 结合使用吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36619122/
我正在尝试创建尽可能小的 ELF。我创建了一个这样的测试文件(NASM 语法): SECTION .text dd 0xdeadbeef 使用此链接描述文件: SECTIONS { .text
GNU LD 链接器命令语言是否有条件语句? 背景:我正在为 arm cortex m0+ 开发固件,该固件由引导加载程序和应用程序组成。两者都在单独的项目中进行编译和刷新,但我使用了一个框架,其中包
我很确定 ld 有一个手册页链接器脚本语法,但我找不到它。 最佳答案 如果您更喜欢比 info 更方便的东西, 这是一个可浏览的 HTML 版本:ld.info: Scripts .但它可能不是完全最
谁能解决这个练习,这样我就能明白我错在哪里,因为有太多的 LOL 变量。 生成一个 C 代码,将其放在以下表达式之前 printf ("% ld% ld% ld \ n", lol, & lol, *
在他关于理解 Linux Kernel Initcall Mechanism 的文章中, Trevor 创建了一个用户空间程序来模拟调用 linux 驱动程序的 init_module() 的机制。
/usr/bin/ld: cannot find -ldlib /usr/bin/ld: cannot find -lcblas /usr/bin/ld: cannot find -llapack 在
我想以 json-ld 格式创建一组人,但我需要保留一些键而不是使用数组,所以我首先尝试了这个: { "@context" : { "@base" : "http://www.exampl
所以我试图围绕 JSON-LD 进行思考,我看到的所有示例主要包括嵌入“链接数据”。但我想提供对链接数据的引用(主要是因为嵌入所有数据可能会产生 10MB 的有效负载)。所以我想知道我这样做是否正确。
我在这里复制了 json-ld standard 中的示例的一部分: { "@context": { "foaf": "http://xmlns.com/foaf/0.1/", "
考虑这样一个程序: #include void foo() __attribute__((__weak__)); int main() { printf("%p\n", (void *)fo
我正在尝试使用一个名为 GLV 的小部件库对于我正在开发的应用程序。我正在运行 Linux Mint 17。我安装了所有库并成功构建了 GLV 库,但是当我尝试运行已构建的示例之一时,出现了此共享库错
在将未编辑的 JSON 数据转换为 JSON-LD 时,使用前缀和数据值为对象构造 IRI 时遇到问题。我运行的示例代码是: { "@context" : { "prefix" : "
假设我有一个 JSON 对象,它在嵌套对象中包含一些属性。 { "title": "My Blog Post", "meta": { "publishedAt": "2
我是 JSON-LD 和 LOD 的新手,所以请原谅我使用的术语。我正致力于在 JSON-LD 中创建数据模型,以描述基于欧洲数据模型 (http://pro.europeana.eu/edm-doc
我有一个玩具 x86 汇编程序,我正在用 as 编写和编译它和 ld : .text .global _start _start: movq $1, %rax movq
我正在尝试创建 Google 的结构化数据,但不知道我在做什么。我将其设置为一个组织,然后将 SD 标记工具用于我的所有产品。我将每个 JSON-LD 产品直接从标记工具而不是嵌套放入它自己的脚本标签
我正在尝试创建 Google 的结构化数据,但不知道我在做什么。我将其设置为一个组织,然后将 SD 标记工具用于我的所有产品。我将每个 JSON-LD 产品直接从标记工具而不是嵌套放入它自己的脚本标签
我正在尝试使用 vcpkg 和 ndk r20 为 android arm 构建 tesseract我必须编辑 CMakeLists.txt 并添加 glob.c 和 glob.h,因为它们不在 nd
长话短说: 有没有办法让我(没有 root 访问权限)使链接器(由 gcc 调用)不知道 /etc/ld.so.conf 中包含的目录的内容 在通过 ldconfig 缓存之后? 详细说明: 我正在尝
我想将/opt/vertica/lib64 添加到系统库路径中,所以我执行以下步骤: (1) 将/opt/vertica/lib64加入/etc/ld.so.conf,运行ldconfig, (2)
我是一名优秀的程序员,十分优秀!