我使用Open API代码生成器Maven插件从一个文件生成Open API 3.0。我在pom.xml中使用这个插件:
<groupId>org.openapitools</groupId>
<artifactId>openapi-generator-maven-plugin</artifactId>
<version>4.3.0</version>
插件生成API没有任何问题,但它使用旧的Swagger注解,而不是使用Swagger v3注解。例如,参数使用@ApiParam
注解,而不是使用io.swagger.v3.oas.annotations
包中的@Parameter
注解:
default ResponseEntity<Fault> getFault(@ApiParam(value = "",required=true) @PathVariable("jobId") String jobId) {
因此,最新的Swagger UI不能正确显示文档。当我使用swagger.v3注解创建一个端点时,Swagger UI工作正常。
根据官方网站https://openapi-generator.tech/docs/plugins/,我应该包括这个依赖项:
<dependency>
<groupId>io.swagger.parser.v3</groupId>
<artifactId>swagger-parser</artifactId>
</dependency>
但是即使有了这种依赖性,插件仍然会生成带有旧注解的源代码。
我如何强制Open API代码生成器使用Swagger v3注解?
2条答案
按热度按时间fzsnzjdm1#
目前不支持V3注解。
您需要覆盖胡子模板。
检查以下PR:
https://github.com/OpenAPITools/openapi-generator/pull/4779
https://github.com/OpenAPITools/openapi-generator/pull/6306
更多信息:
https://github.com/OpenAPITools/openapi-generator/issues/6108
https://github.com/OpenAPITools/openapi-generator/issues/5803
您可以使用上述PR中的升级模板,也可以在合并时等待。
iklwldmw2#
现在发布了5.3.1版本的插件,我使用了来自https://github.com/OpenAPITools/openapi-generator/pull/9775和https://github.com/OpenAPITools/openapi-generator/issues/6108的信息来使它为我工作。
我在pom.xml中添加了三个configOptions:
之后,可能需要添加另一个依赖项作为解决方法,因为插件会将未使用的导入添加到生成的代码中。
我使用的是springdoc-openapi-ui依赖项。