Swagger/OpenAPI annotations V3 - use Enum values in swagger annotations(Swagger/OpenAPI批注V3-在swagger批注中使用枚举值)
问题描述
我正在使用Swagger/OpenApi V3批注创建应用程序的API描述,这些批注是从以下依赖项导入的:
<dependency>
<groupId>org.springdoc</groupId>
<artifactId>springdoc-openapi-ui</artifactId>
<version>1.1.45</version>
</dependency>
其中一个批注是@Schema
批注,它接受名为allowableValues
的属性,该属性允许字符串数组:
@Schema(description = "example",
allowableValues = {"exampleV1", "exampleV2"},
example = "exampleV1", required = true)
private String example;
现在,我想使用在Enum类上构造的自定义方法,该方法返回允许的字符串数组,因此不需要在每次向Enum添加类型时添加它。这样我们就可以这样使用它:
public enum ExampleEnum {
EXAMPLEV1, EXAMPLEV2;
public static String[] getValues() {...}
}
@Schema(description = "example",
allowableValues = ExampleEnum.getValues(),
example = "exampleV1", required = true)
private String example;
现在无法编译,因为在执行注释时该方法是未知的。 是否有这样的解决方案允许在swagger V3批注属性值中使用枚举?
查看以下资源:
- https://swagger.io/docs/specification/data-models/enums/
最坏的情况是,我确实可以在一个常量位置定义它,并且在将类型添加到Enum之后,只需要将该类型添加到另一个位置。但如果可能的话,我首先想探讨一下上面提到的解决方案。您可以在全局组件部分定义可重复使用的枚举,并在其他地方通过$ref引用它们。
- https://github.com/swagger-api/swagger-core/wiki/Swagger-2.X---Annotations#schema
未说明有关使用任何类或动态生成值的任何内容。
- Enum in swagger
是关于在swagger中记录枚举,而不是在swagger批注API中使用它们。
推荐答案
尝试使用@Schema(implementation = ExampleEnum.class, ...)
,您可以添加所需的所有其他属性。我需要有关您的实施的更多信息,但请先尝试此操作。
这篇关于Swagger/OpenAPI批注V3-在swagger批注中使用枚举值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Swagger/OpenAPI批注V3-在swagger批注中使用枚举值
基础教程推荐
- 首次使用 Hadoop,MapReduce Job 不运行 Reduce Phase 2022-01-01
- 如何在不安装整个 WTP 包的情况下将 Tomcat 8 添加到 Eclipse Kepler 2022-01-01
- 在螺旋中写一个字符串 2022-01-01
- Spring Boot Freemarker从2.2.0升级失败 2022-01-01
- 如何强制对超级方法进行多态调用? 2022-01-01
- 如何使用 Stream 在集合中拆分奇数和偶数以及两者的总和 2022-01-01
- 如何对 HashSet 进行排序? 2022-01-01
- Java 中保存最后 N 个元素的大小受限队列 2022-01-01
- 由于对所需库 rt.jar 的限制,对类的访问限制? 2022-01-01
- 如何使用 Eclipse 检查调试符号状态? 2022-01-01