• Swagger enum 最佳实践:深度剖析与应用指南


    enumSwagger 规范中用来定义枚举类型的一种方式。它允许开发者在 API 文档中明确列出该接口的参数、返回值或请求体中可接受的枚举值。通过使用 Swagger enum,开发者可以更清晰地描述 API 的输入和输出,提高 API 文档的可读性和可维护性。

    enum 使用场景

    在以下情况下,使用 Swagger enum 功能是非常有意义的:

    1. API 接口 的参数或返回值具有预定义的枚举值时,使用 Swagger enum 可以明确告知使用者可以选择的选项。
    2. 当 API 接口有多个可能的状态时,使用 Swagger enum 可以减少开发者需要查看 API 源代码的次数,从而更快地理解 API 的用法。
    3. 当使用了前后端分离的开发架构时,Swagger enum 可以作为后端开发人员与前端开发人员之间统一枚举值的约定。

    enum 用法介绍

    在 Swagger 规范中,使用 enum 关键字定义枚举值。例如,我们可以在参数定义中使用 enum 来明确指定参数的可选值:

    1. parameters:
    2. - name: status
    3. in: query
    4. required: true
    5. type: string
    6. enum:
    7. - active
    8. - inactive

    在这个示例中,status 参数的可能取值只能是 activeinactive

    实践案例

    当使用 Swagger Editor 来编辑和运行 Swagger 定义时,可以使用以下示例在枚举类型中使用 Swagger enum:

    1. swagger: "2.0"
    2. info:
    3. title: Example API
    4. version: 1.0.0
    5. paths:
    6. /pets:
    7. post:
    8. summary: Add a new pet to the store
    9. parameters:
    10. - name: petSize
    11. in: query
    12. description: The size of the pet
    13. required: true
    14. type: string
    15. enum:
    16. - small
    17. - medium
    18. - large
    19. responses:
    20. 200:
    21. description: OK

    Swagger Editor 中,将以上文本粘贴到编辑器中,你会看到右侧的 Swagger UI 将显示你的 API。你可以尝试发送请求以查看效果。

    当你向/pets发送 POST 请求时,你将需要在查询参数中传递petSize的值。尝试将petSize设置为smallmediumlarge之外的其他值,并发送请求。你将会看到 Swagger UI 会标示出你的请求是无效的,并在文档中明确列出可选的枚举值。

    这个示例可以在 Swagger Editor 中运行并进行测试,以展示 Swagger enum 的使用方式。

    在 SpringBoot 中配置注解

    在 Spring Boot 中,你可以使用@ApiModelProperty注解来配置 Swagger 枚举类型。

    首先,确保在你的项目中添加了 Swagger 的依赖。在pom.xml文件中添加以下依赖:

    1. <dependency>
    2. <groupId>io.springfox</groupId>
    3. <artifactId>springfox-swagger2</artifactId>
    4. <version>2.9.2</version>
    5. </dependency>
    6. <dependency>
    7. <groupId>io.springfox</groupId>
    8. <artifactId>springfox-swagger-ui</artifactId>
    9. <version>2.9.2</version>
    10. </dependency>

    接下来,在你的枚举字段上使用@ApiModelProperty注解进行配置。例如,假设你有一个名为Pet的实体类,其中包含一个size字段,它使用了枚举类型:

    1. import io.swagger.annotations.ApiModelProperty;
    2. public class Pet {
    3. @ApiModelProperty(value = "The size of the pet", allowableValues = "SMALL, MEDIUM, LARGE")
    4. private Size size;
    5. // ...
    6. }

    在上述示例中,我们使用了@ApiModelProperty注解来指定字段的描述和可选值。allowableValues属性用于指定可选的枚举值,每个值用逗号分隔。

    然后,使用@ApiModel注解来对实体类进行配置:

    1. import io.swagger.annotations.ApiModel;
    2. @ApiModel(description = "Pet entity")
    3. public class Pet {
    4. // ...
    5. }

    接下来,配置 Swagger 的 Docket Bean 来启用 Swagger 并设置相关配置。在你的 Spring Boot 应用程序主类中,添加以下代码:

    1. import springfox.documentation.swagger2.annotations.EnableSwagger2;
    2. @SpringBootApplication
    3. @EnableSwagger2
    4. public class YourApplication {
    5. public static void main(String[] args) {
    6. SpringApplication.run(YourApplication.class, args);
    7. }
    8. @Bean
    9. public Docket api() {
    10. return new Docket(DocumentationType.SWAGGER_2)
    11. .select()
    12. .apis(RequestHandlerSelectors.any())
    13. .paths(PathSelectors.any())
    14. .build();
    15. }
    16. }

    以上代码配置了一个名为api的 Docket Bean 来启用 Swagger,并设置了扫描所有请求处理程序和路径的条件。

    然后,启动你的 Spring Boot 应用程序并访问 Swagger UI 界面(通常是http://localhost:8080/swagger-ui.html)。你将看到你的枚举类型字段显示了可选的枚举值。

    注意事项

    使用 Swagger enum 时需要注意以下几点:

    1. 枚举值应该是唯一且具有描述性的,以方便开发者理解每个选项的含义。
    2. 当枚举值数量较多时,建议将其定义为一个单独的类,以提高可读性。
    3. 在修改枚举值时,需要确保 API 的使用者也同步更新了对应的枚举值。

    常见问题和解决方案

    • 枚举值定义错误导致接口调用失败:请确保在枚举定义中使用的值与接口定义一致。
    • 枚举类中的值和实际应用不一致:请确保在修改枚举类时同步更新 API 接口。

    Swagger 和 Apifox 整合

    你可以在 IDEA 中自动同步 Swagger 注解到 Apifox,一键生成接口文档,多端同步,非常方便测试和维护,这样就可以迅速分享 API 给其他小伙伴。

    Apifox 的 IDEA 插件可以自动解析代码注释,并基于 Javadoc、KDoc 和 ScalaDoc 生成 API 文档。通过 IntelliJ IDEA 的 Apifox Helper 插件,开发人员可以在不切换工具的情况下将他们的文档与 Apifox 项目同步。

    当在 IDEA 项目中有接口信息变动,只需右键点击「 Upload to Apifox」一键即可完成同步,无需奔走相告。 团队成员可在 Apifox 中看到同步后的最新内容。

    最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

    这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你! 

  • 相关阅读:
    通过Keil如何查看MCU的RAM与ROM使用情况
    LeetCode59.螺旋矩阵
    【Git CMD】Git上传本地代码到远程仓库(6步到位)
    ucinet再相见
    Intel oneAPI笔记(2)--jupyter官方文档(oneAPI_Intro)学习笔记
    创新视频剪辑:轻松实现批量垂直翻转,提高视频品质与吸引力
    基于node.js+Vue在线电子商务购物商城系统 Element
    WebGL笔记:绘制多个点,三角形,以及画各种不同的线条,面
    CTF入门指南
    【一】【计算机网络】win基本命令
  • 原文地址:https://blog.csdn.net/NHB234567/article/details/136763692