SpringDoc介绍

一、SpringDoc

官方文档

1.1何为SpringDoc

        SpringDoc是一个用来自动生成API文档的库。它是基于SpringBoot项目的,遵循OpenAPI3(一个组织规定的规范)规范。它是通过检查我们运行中的程序,推断出基于Spring配置、类结构和各种注解的API语义,从而自动生成JSON、YAML和HTML格式的接口文档。

        而我们不得不提的就是Swagger。Swagger是一个公司的开源项目,将自己的API设计贡献给了OpenAPI并由其标准化。在SpringDoc之前我们还可以使用Springfox,和SpringDoc一样是一个用于生成API文档的库,2020年起不再更新。

1.2添加SpringDoc

        我们现在学习SpringDoc的使用。

         我们添加SpringDoc的依赖。

<dependency>
    <groupId>org.springdoc</groupId>
    <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
    <version>2.6.0</version>
</dependency>

        而在我们的项目运行之后,我们按照下面链接的格式访问即可。其中有一些常量我们可以自己设置。(html格式)

http://server:port/context-path/swagger-ui.html

        一般来说有如下。 

http://localhost:8080/swagger-ui.html

        当然我们也可以去访问json的或yml的,但是不好看。 而且不能进行发请求。

        我们可以在yml文件当中去配置一些信息。

springdoc:
  api-docs:
    # 是否开启接口文档
    enabled: true
    swagger-ui:
      # 持久化认证数据
      persistAuthorization: true
  info:
    # 标题
    title: '标题:${demo.name}多租户管理系统_接口文档'
    # 描述
    description: '描述:用于管理集团旗下公司的人员信息,具体包括XXX,XXX模块...'
    # 版本
    version: '版本号: ${demo.version}'
    # 作者信息
    contact:
      name: Agazigi
      email: 123456789@qq.com
      url: www.baidu.com
  components:
    # 鉴权方式配置
    security-schemes:
      apiKey:
        type: APIKEY
        in: HEADER
        name: ${sa-token.token-name}
  #这里定义了两个分组,可定义多个,也可以不定义
  group-configs:
    - group: 1.演示模块
      packages-to-scan: org.dromara.demo
    - group: 2.通用模块
      packages-to-scan: org.dromara.web
    - group: 3.系统模块
      packages-to-scan: org.dromara.system
    - group: 4.代码生成模块
      packages-to-scan: org.dromara.generator

1.3使用SpringDoc 

        我们先完成一个简单的Controller层。

        接着我们访问上边的路径。

1.4详解SpringDoc

1.4.1文档信息设置

        步骤一:创建API文档配置类。

        步骤二:将OpenAPI对象交给IoC容器管理。

        步骤三:对OpenAPI对象进行设定。

1.4.2常用注解

注解含义
@Tag用在controller类上,描述此controller的信息
@Operation用在controller的方法里,描述此api的信息
@Parameter用在controller方法里的参数上,描述参数信息
@Parameters用在controller方法里的参数上
@Schema用于Entity,以及Entity的属性上
@ApiResponse用在controller方法的返回值上
@ApiResponses用在controller方法的返回值上
@Hidden用在各种地方,用于隐藏其api
@NotNull、@Min、@Max非空、值的最大、最小

 1.4.3注解简化

1.4.4配置认证

        步骤一:Application启动类上加@SecurityScheme,并设置信息。

        步骤二:添加其配置。

        步骤三:设计过滤器。

        步骤四:验证结果。

1.4.5文档分组

1.4.6配置信息

<think>嗯,用户想了解Ruoyi-Plus中的SpringDoc。首先,我需要回忆一下Ruoyi-Plus是什么,它是一个基于Spring Boot的快速开发框架,可能是在若依框架基础上的增强版。SpringDoc应该是用来生成API文档的工具,类似Swagger,但支持OpenAPI 3.0。 接下来,我需要确定用户的具体需求。他们可能是在使用Ruoyi-Plus时遇到了集成API文档的问题,或者想了解如何利用SpringDoc来自动生成文档。需要分步骤介绍SpringDoc在Ruoyi-Plus中的应用,包括配置、注解使用、访问路径等。 然后,考虑用户可能的疑问点,比如如何引入依赖、配置类的作用、常用注解,以及如何访问生成的文档。确保回答结构清晰,分点说明,并给出实际代码示例,比如配置类和控制器注解的使用。同时,需要注意Ruoyi-Plus可能有自己的安全配置,需要排除SpringDoc的路径,避免被拦截。 还要检查是否需要对比SpringDoc和Swagger的区别,说明为什么选择SpringDoc,可能因为对OpenAPI 3.0的支持更好。另外,提醒用户注意版本兼容性和生产环境的关闭建议,这些都是实际开发中容易遇到的问题。 最后,确保使用中文,符合格式要求,数学公式正确使用$...$和$$...$$,但在这里可能用不上数学公式,不过要检查是否有其他格式要求。保持回答简洁明了,帮助用户一步步解决问题,并确保信息准确可靠。</think>在Ruoyi-Plus框架中,SpringDoc的集成与使用可以通过以下步骤理解: --- ### 一、SpringDoc基础概念 SpringDoc是基于OpenAPI 3规范的开源工具,用于自动生成API文档(替代传统的Swagger)。在Ruoyi-Plus中主要用于: 1. 自动扫描控制器生成可视化API文档 2. 支持在线测试接口 3. 提供交互式文档界面 --- ### 二、Ruoyi-Plus中的配置实现 #### 1. 依赖引入 ```xml <!-- pom.xml中需包含 --> <dependency> <groupId>org.springdoc</groupId> <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId> <version>2.1.0</version> </dependency> ``` #### 2. 配置类示例 ```java @Configuration public class OpenApiConfig { @Bean public OpenAPI ruoyiPlusOpenAPI() { return new OpenAPI() .info(new Info().title("Ruoyi-Plus API") .description("企业级开发框架接口文档") .version("v1.0") .contact(new Contact().name("技术支持"))); } } ``` #### 3. 安全配置排除(重要) 在SecurityConfig中添加: ```java .antMatchers("/swagger-ui/**", "/v3/api-docs/**").permitAll() ``` --- ### 三、核心注解使用 在Controller层使用: ```java @Tag(name = "用户管理模块") @RestController @RequestMapping("/system/user") public class SysUserController { @Operation(summary = "获取用户列表") @GetMapping("/list") public TableDataInfo list(SysUser user) { // ... } @Parameter(name = "userId", description = "用户ID", required = true) @GetMapping("/{userId}") public AjaxResult getInfo(@PathVariable Long userId) { // ... } } ``` --- ### 四、文档访问路径 1. **API JSON描述**:`http://localhost:port/v3/api-docs` 2. **可视化界面**:`http://localhost:port/swagger-ui.html` --- ### 五、与Swagger的区别 | 特性 | SpringDoc | Swagger | |---------------------|---------------------|--------------------| | OpenAPI版本支持 | 3.0+ | 2.0 | | Spring Boot集成 | 原生支持 | 需要额外配置 | | 注解包路径 | `io.swagger.v3` | `io.swagger` | --- ### 六、注意事项 1. **版本兼容性**:需与Spring Boot版本匹配 2. **生产环境**:建议通过`springdoc.swagger-ui.enabled=false`关闭 3. **权限控制**:结合Ruoyi-Plus的@RequiresLogin注解实现访问控制 通过上述配置,Ruoyi-Plus可以快速生成符合OpenAPI 3规范的接口文档,提升前后端协作效率。实际使用中建议结合具体业务需求扩展文档描述信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值