- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我第一次尝试使用 OAS 3.0、Swagger Codegen、Spring MVC 和 Spring HATEOAS 创建 RESTful API。我想使用 OAS 定义来生成文档和服务器/客户端 stub ,并使用 HATEOAS 创建超链接相关资源。
我目前的资源已扩展 ResourceSupport
并可以添加我的链接,以便回复具有 _embedded
和_links
我所期望的领域。我的问题是如何正确映射 HATEOAS Resource
到 Swagger codegen 生成的模型。我的 OAS 定义与 hal+json
匹配响应,因此 swagger 模型和我的 HATEOAS Response
中的字段是相同的.
有没有办法轻松映射这些?我也愿意接受我对这一点的错误解释,并且这些框架并没有真正融合在一起。
美洲国家组织示例:
responses:
200:
description: ...
content:
application/hal+json:
schema:
$ref: '#/components/schemas/OasPersonResponse'
components:
schemas:
OasPersonResponse:
type: object
properties:
firstName:
type: string
lastName:
type: string
_links:
type: object
properties:
self:
type: object
properties:
href:
type: string
Resource
示例:
public class PersonResource extends ResourceSupport {
private final Person person;
public PersonResource(Person person) {
this.person = person;
}
public String getFirstName() {
return person.getFirstName();
}
public String getLastName() {
return person.getLastName();
}
}
Controller 示例:
@Controller
public class PersonController implements PersonApi {
@Override
public ResponseEntity<OasPersonResponse> getPersonById(Integer personId) {
Person person = someDb.getPerson(personId);
PersonResource personResource = new PersonResource(person);
personResource
.add(linkTo(methodOn(PersonController.class)
.getPersonById(personId))
.withSelfRel();
Resource<PersonResource> returnResource =
new Resource(personResource);
return new ResponseEntity<>(returnResponse, HttpStatus.OK);
}
我的问题是 swagger codegen 生成的 stub 期望返回类型为 ResponseEntity<OasPersonResponse>
但有一个引用Resource<PersonResource>
。两者OasPersonResponse
和PersonResource
表示相同的数据,但 OasPersonResponse
明确定义 _links
对象,而响应为 PersonResource
被序列化为 _links
对象。
有没有一种简单的方法可以将 HATEOAS 资源转换为 swagger codegen 创建的模型?
预先感谢您的帮助和指导。
最佳答案
我目前正在开发一个非常相似的项目!首先,如果可以的话,我建议使用 spring-hateoas 的 1.0.0.RC1 版本,因为它比 0.25.x 发行版分支有一些相当重大的生活质量改进。最重要的是,现在推荐使用 EntityModel 包装类,这意味着您可以将关系排除在基本实体规范之外。 (缺点是这降低了 OpenAPI 规范的直接效用;我还没有完全弄清楚如何协调这一点。)
其次,恐怕 swagger-codegen 方面在支持 Spring HATEOAS 方面似乎没有太多现有的工作;事实上,我一直在使用普通的 Spring“语言”生成器时遇到烦人的错误。
因此,我们要么可以为 spring-hateoas 编写自己的 swagger-codegen 生成器,要么只是大量自定义一些模板以使其“足够接近”(使用 EntityModel 包装器而不是扩展 ResourceSupport 时需要的东西较少)。到目前为止,我已经采用了后一种方法,因为它是值得的。
关于java - Swagger Codegen 3 和 Spring HATEOAS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56245639/
我试图在我的微服务项目中生成一个单一的 swagger,在 Api 网关中将所有服务 swagger 聚合成一个单一的服务。为了实现这一点,我正在学习下一个教程 https://objectpartn
我的任务是将 Swagger 安装到 Web API 项目中。 已安装:来自 nuget 的最新版本的 Swashbuckle。 (Swashbuckle.Core.Net45 和 Swashbuck
我正在编写一个 swagger 规范,并且我有三个独立的端点。我如何在文档中将它们分开?我想明确区分示例:用户、帖子和其他。所以每个人都会有一个 CRUD 描述并显示在 swagger UI 中,它看
我试图在 Swagger 中定义一个查询参数,其中包含来自预定义项目集的逗号分隔字符串,例如 ?fruits=Apples,Oranges,Bananas但我从 swagger 编辑器收到以下错误 s
我正在使用 go-swagger 来生成 API 服务器。我注意到从 swagger.yml 生成的 json 被保存在 restapi/embedded_spec.go 中. 公开该 JSON 规范
我使用的是 springfox 版本 2.9.2 和 swagger 注释 1.5.x。 ApiModel 注释支持鉴别器、子类型和父属性,这些是使多态性工作所需的,但我没有看到生成的正确的 apid
我正在尝试使用本地 swagger.json 文件在 swagger 文档中显示。 我的 swagger.json 文件位于/home/user1/swagger-ui/dist/swagger.js
我们有一些数字字段,由于遗留原因,它们具有隐式长度限制。 给定一个长度限制为 5 的数字字段,显而易见的方法是将最大值设置为 99999,但是有没有办法在 swagger 规范中指定 1.111 可以
我们的项目为单个 API 使用多个 swagger 文件,但看起来 swagger-codegen 只接受一个。在这种情况下,我们如何使用 swagger-codegen 生成代码? 最佳答案 您可以
我正在尝试使用 https://github.com/swagger-api/swagger-codegen 生成 nodejs 客户端 sdk这是我使用的命令 swagger-codegen gen
我定义了一个以 MyObject 作为参数的路径。 MyObject 具有猫和狗的属性。这些有默认值。 在 swagger-editor 中,该示例不显示默认值,但试用确实创建了一个具有正确默认值的
我最近从 Swashbuckle 过渡到 Swagger-Net .进行更改后我遇到的一个问题是,现在我无法调用需要在 Authorization header 中发送 token 的 API。下面是
正在使用 AspNetCore 为使用 IIS 托管的 Web 应用程序设置 swagger。 .json 页面加载并且似乎可以很好地接触所有 API,但是当导航到 {localhost}/swagg
我想将任何复杂的 swagger-API-document(swagger.json) 解析为 Java 对象。 可能是列表> 有哪些可用选项? 我正在尝试使用 io.swagger.parser.S
我要将我的 API 服务器集成到 Google Cloud Endpoints。 到目前为止,Google Cloud Endpoints 支持 swagger 2.0。 但是我的依赖项/库现在是 u
我是 swagger 的新手,发现有两个用于 swagger 注释的包:io.swagger.annotations 和 com.wordnik.swagger.annotations。我想知道它们之
好的,我有许多 io.swagger.models.Swagger 对象,我已将它们合并到一个新的 super Swagger 中。现在我想要 super html。我怎样才能得到这个?请注意,为了获
我们当前的部署模式要求我手动编写 swagger json 输出,该输出将由我公司使用的基于 Swagger 的 UI 使用。我希望我正在编写的 json 能够提供“默认”值来填充所有输入字段(包括
我有以下 HTTP 触发的 Azure 函数。我已经使用此链接为我的端点设置了 Swagger here .以下 API 需要一组查询字符串参数,即 "name"、"email"、"phone",因此
我正在努力让 Swagger 正确呈现我的 ServiceStack 服务。 我希望看到一个 UserId 字符串作为表单参数,一个 PrivateCustomer 对象作为主体参数,但是尽管 Use
我是一名优秀的程序员,十分优秀!