11.SpringBoot配置Swagger3 - 技术博客
程序智享家
精彩内容加载中

11.SpringBoot配置Swagger3

Swagger3(也被称为OpenAPI 3)是一个开放源代码项目,它定义了用于描述、生产、消费和可视化RESTful Web服务的规范。

admin 2025-02-10 1228 阅读 0 评论 java框架

一.Swagger3的主要功能

  • 自动生成API文档:Swagger3可以根据项目中的注解自动生成API文档,大大提高了开发效率。
  • 可视化界面:Swagger3提供了可视化界面,方便开发者查看和测试API。
  • 支持多种格式:Swagger3不仅支持JSON格式,还支持YAML格式,可以减少文本长度,提高可读性。
  • 组件化:Swagger3采用了组件化的方式来定义API元素,使得API定义更加模块化和可扩展。
  • 安全认证:Swagger3支持API的安全认证,可以通过配置安全方案和上下文来保护API的安全。

二.Swagger3的集成与使用

  1. 引入依赖:在项目中引入Swagger3的依赖,通常是通过Maven或Gradle等构建工具来完成的。
  2. 配置Swagger:创建Swagger配置类,通过注解和配置来定制Swagger的文档信息、安全认证等。
  3. 编写注解:在Controller类和方法上编写Swagger的注解,如@Api、@ApiOperation、@ApiModel、@ApiModelProperty等,这些注解会被Swagger解析并生成对应的API文档。
  4. 启动项目:启动项目后,通过访问Swagger的UI界面(通常是http://localhost:端口号/swagger-ui/index.html)来查看和测试API。

三、Swagger3的常用注解

  1. @Api:用于接口类上,用以对当前的接口类做整体声明。
  2. @ApiOperation:用于接口方法上,用以描述具体的方法。
  3. @ApiModel:用于实体类上,描述实体类的整体信息。
  4. @ApiModelProperty:用于实体类的属性上,描述属性的详细信息。
  5. @ApiImplicitParams和@ApiImplicitParam:用于描述接口方法的隐式参数。
  6. @ApiResponses和@ApiResponse:用于描述接口方法的响应信息。
  7. @ApiIgnore:用于忽略某个接口或方法,使其在Swagger文档中不可见。

四、Swagger3与Swagger2的区别

  1. OpenAPI规范的支持:Swagger3采用OpenAPI规范来定义API,这使得API定义更加规范化和标准化。而Swagger2是OpenAPI规范的前身。

  2. 支持的格式:Swagger3除了支持JSON格式外,还支持YAML格式。而Swagger2主要支持JSON格式。

  3. 特性支持:Swagger3支持异步API、Webhook等特性,而Swagger2则没有这些支持。

  4. 组件化:Swagger3采用了组件化的方式来定义API元素,更加模块化和可扩展。而Swagger2的组件化支持相对较弱。

五、Swagger3的优缺点

优点:

  1. 自动生成API文档,提高开发效率。
  2. 提供可视化界面,方便查看和测试API。
  3. 支持多种格式和组件化定义,提高API的可读性和可扩展性。

缺点:

  1. 在某些Spring Boot版本中可能存在兼容性问题,需要额外配置或降级版本。
  2. 对于复杂的API定义和文档定制,可能需要较多的配置和注解编写。
  3. 综上所述,Swagger3是一个功能强大且灵活的API文档生成和可视化工具,它可以帮助开发者更好地设计和维护API文档,提高开发效率和文档的可读性。在实际项目中,开发者应根据项目需求和团队习惯来选择合适的版本和配置方式。

六.SpringBoot配置Swagger3

1.在pom.xml中引入Swagger3包。

<!--引入Swagger3-->
<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-boot-starter</artifactId>
    <version>3.0.0</version>
</dependency>
<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>swagger-bootstrap-ui</artifactId>
    <version>1.9.6</version>
</dependency>

2.新建一个配置文件,编写配置文件

package com.tms.tblog.infrastructure.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;

@Configuration
public class SwaggerConfig {
    @Bean
    public Docket docket() {
        return new Docket(DocumentationType.OAS_30).apiInfo(
                new ApiInfoBuilder()
                        .title("Swagger2接口项目")
                        // 创建人信息
                        .version("1.0")
                        // 描述
                        .description("API接口")
                        .build()
        );

    }
}

3.兼容问题处理

如果使用的是SpringBoot2.6.1可能会有一个问题Failed to start bean 'documentationPluginsBootstrapper'; ,在启动文件里加上 @EnableWebMvc注解

package com.tms.tblog;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;

@SpringBootApplication
@MapperScan("com.tms.tblog.dao")
@EnableWebMvc
public class TBlogApplication {

    public static void main(String[] args) {
        SpringApplication.run(TBlogApplication.class, args);
    }

}

七编写测试代码

1.在Controller中写上接口的api注解

/**
 * 账户控制
 */
@Api(tags = "账户接口")
@RequestMapping("/Account")
@RestController
@Log4j2
public class AccountController {

    @Resource
    private AccountService accountService;

    /**
     * 获取所有账户信息
     *
     * @return
     */
    @ApiOperation(value = "获取账户接口")
    @RequestMapping(value = "getAccount", method = RequestMethod.GET)
    public List<Account> getAccount() {
        List<Account> list = accountService.getAccount();
        return list;
    }
}

2.运行结果

八.常用的注解

| 注解 | 注解位置 | | ------------ | ------------ | | @Api(tags=“接口描述”) | controller类上 | | @Operation(summary = “接口方法描述”) | controller 方法上 | | @ApiModelProperty(value = “字段描述”) | JavaBean的字段上 | | @ApiModel(“实体类的描述”) | JavaBean上 | | @EnableOpenApi | 配置类上 | | @ApiImplicitParams | controller的方法参数中 | | @ApiImplicitParam | @ApiImplicitParams 下的的子参数 | | @Parameter(description = “参数描述”) | controller 方法的参数中 |

推荐阅读

7.SpringBoot使用Aop监控接口的执行状况 AOP(Aspect Oriented Programming),即面向切面编程,可以说是OOP(Object Oriented Programming,面向对… 5.SpringBoot配置自动生成代码 AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper… 4.SpringBoot配置MyBatis-Plus MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBa… 3.Springboot配置跨域 Springboot配置跨域有很多种方式,今天我们来看一下有哪几种方式,第一种方法还是比较常见的。… 2.SpringBoot配置lombok Lombok想要解决了的是在我们实体Bean中大量的Getter/Setter方法,以及toString, hashCode等可能不会用到,但是某些时候仍然需要… 1.SpringBoot框架搭建 Spring Boot 是 Pivotal 团队在 Spring 的基础上提供的一套全新的开源框架,其目的是为了简化 Spring 应用的搭建和开发过程。… 8.Springboot整合log4j2日志 Apache Log4j 2 是对 Log4j 的升级,它比其前身 Log4j 1.x 提供了重大改进,并提供了 Logback 中可用的许多改进,同时修复了 … 9.SpringBoot配置Redis Redis(Remote Dictionary Server ),即远程字典服务,是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、… 10.SpringBoot配置Druid连接池 连接池的作用是为了提高性能,将已经创建好的连接保存在池中,当有请求来时,直接使用已经创建好的连接对Server端进行访问。这样省略(复用)了创建连接和销毁连接的… 12.SpringBoot统一异常处理 在 Spring Boot 应用中,统一异常处理是一种非常实用的技术,它可以帮助我们集中管理和处理应用程序中抛出的异常,避免在每个控制器方法中重复编写异常处理代… 13.SpringBoot配置Thymeleaf Thymeleaf是一个java类库,他是一个优秀的、面向Java 的xml/xhtml/html5的模板引擎,可以作为mvc的web应用的view层,具有丰富… 14.SpringBoot图片文件上传 图片文件上传是经常会用到的功能,尤其是做一些大型企业网站。… 15.Springboot多模块配置 在开发大型项目时,使用 Spring Boot 多模块配置可以将项目拆分成多个独立的模块,便于团队协作开发、代码管理和维护。以下为你详细介绍 Spring Bo… 16.SpringBoot配置SSL证书 在 Spring Boot 中配置 SSL 证书可以为应用程序提供安全的 HTTPS 连接,增强数据传输的安全性。… 17.SpringBoot项目打包成jar包 打包springboot项目有两种方法,一个是直接通过mvn命令打包,另一个是使用工具打包,例如idea… 18.SpringBoot实现图片压缩 在上传图片的时候进行图片压缩,这样虽然破环了原图片的清晰度,不影响图片的美感,博客用来作为缩略图正好。… 19.Java生成sitemap网站地图 Sitemap(网站地图)在网站管理和搜索引擎优化(SEO)中扮演着重要角色。在Java中生成网站地图(sitemap)通常涉及创建一个XML文件,该文件列出了… 20.springboot使用Jsoup解析html,抓取一个网站上的全部链接 soup 是一款Java 的HTML解析器,可直接解析某个URL地址、HTML文本内容。它提供了一套非常省力的API,可通过DOM,CSS以及类似于jQuery… 21.Springboot使用Jsoup和sitemapgen4j动态生成网站地图 Sitemapgen4j是一个使用Java编写的Sitemap输出库包,通过使用SitemapGen4j你可以可以添加任意数量的URL,可以得到gzip压缩输出…

评论 (0)

暂无评论,快来抢沙发吧