如何详细编写SpringBoot整合Swagger2生成在线API文档的代码?

2026-04-30 03:083阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计752个文字,预计阅读时间需要4分钟。

如何详细编写SpringBoot整合Swagger2生成在线API文档的代码?

第一部分:集成 Swagger2

在 pom.xml 中添加以下依赖:

xml io.springfox springfox-swagger-ui 2.4.0

第一部分:代码集成

pom.xml

<!--swagger2配置--> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.4.0</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.4.0</version> </dependency> <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>swagger-bootstrap-ui</artifactId> <version>1.6</version> </dependency>

swagger2配置类

package com.liud.demo.config; import io.swagger.annotations.ApiOperation; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import springfox.documentation.builders.ApiInfoBuilder; import springfox.documentation.builders.PathSelectors; import springfox.documentation.builders.RequestHandlerSelectors; import springfox.documentation.service.ApiInfo; import springfox.documentation.service.Contact; import springfox.documentation.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; import springfox.documentation.swagger2.annotations.EnableSwagger2; /** * TODO * swagger2配置类 * @author liud * @version 1.0 */ @Configuration @EnableSwagger2 public class Swagger2 { //配置swagger2核心配置 @Bean public Docket createRestApi(){ return new Docket(DocumentationType.SWAGGER_2) //指定api类型位swagger2 .apiInfo(apiInfo()) //用于定义api文档汇总信息 .select() //.apis(RequestHandlerSelectors.basePackage("com.liud.demo.controller")) //指定生成文档的controller //.apis(RequestHandlerSelectors.any()) //为任何接口生成API文档 //.apis(RequestHandlerSelectors.withClassAnnotation(Api.class)) //为有@Api注解的Controller生成API文档 .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)) //为有@ApiOperation注解的方法生成API文档 .paths(PathSelectors.any()) .build(); } //api基本信息 private ApiInfo apiInfo(){ return new ApiInfoBuilder() .title("SpringBootDemo的项目接口API") //文档标题 .contact(new Contact("liud", //作者 "", "")) //联系人 .description("SpringBootDemo的项目接口API")//详细信息 .version("1.0.0")//文档版本号 .termsOfServiceUrl("")//网站地址 .build(); } }

Controller

package com.liud.demo.controller; import com.liud.demo.service.HelloService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.*; import javax.servlet.{ip}:{port}/swagger-ui.html#/

我的地址:127.0.0.1:8081/swagger-ui.html

②文档模式

在浏览器上输入url:
{ip}:{port}/doc.html

我的地址:127.0.0.1:8081/doc.html

第三部分 swagger2常用注解

常用注解:

@Api()用于类;
表示标识这个类是swagger的资源
tags–表示说明
value–也是说明,可以使用tags替代
但是tags如果有多个值,会生成多个list


效果:

如何详细编写SpringBoot整合Swagger2生成在线API文档的代码?

@ApiOperation()用于方法;
表示一个http请求的操作
value用于方法描述
notes用于提示内容
tags可以重新分组(视情况而用)

@ApiParam()用于方法,参数,字段说明;
表示对参数的添加元数据(说明或是否必填等)
name–参数名
value–参数说明
required–是否必填

@ApiParam(name="username",value = "用户名",required = true) String username

效果:

  • @ApiModel()用于类
  • 表示对类进行说明,用于参数用实体类接收
  • @ApiModelProperty()用于方法,字段
  • 表示对model属性的说明或者数据操作更改
  • @ApiIgnore()用于类,方法,方法参数
  • 表示这个方法或者类被忽略
  • @ApiImplicitParam() 用于方法
  • 表示单独的请求参数
  • @ApiImplicitParams() 用于方法,包含多个@ApiImplicitParam

到此这篇关于SpringBoot集成Swagger2构建在线API文档的文章就介绍到这了,更多相关SpringBoot集成Swagger2内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

本文共计752个文字,预计阅读时间需要4分钟。

如何详细编写SpringBoot整合Swagger2生成在线API文档的代码?

第一部分:集成 Swagger2

在 pom.xml 中添加以下依赖:

xml io.springfox springfox-swagger-ui 2.4.0

第一部分:代码集成

pom.xml

<!--swagger2配置--> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.4.0</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.4.0</version> </dependency> <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>swagger-bootstrap-ui</artifactId> <version>1.6</version> </dependency>

swagger2配置类

package com.liud.demo.config; import io.swagger.annotations.ApiOperation; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import springfox.documentation.builders.ApiInfoBuilder; import springfox.documentation.builders.PathSelectors; import springfox.documentation.builders.RequestHandlerSelectors; import springfox.documentation.service.ApiInfo; import springfox.documentation.service.Contact; import springfox.documentation.spi.DocumentationType; import springfox.documentation.spring.web.plugins.Docket; import springfox.documentation.swagger2.annotations.EnableSwagger2; /** * TODO * swagger2配置类 * @author liud * @version 1.0 */ @Configuration @EnableSwagger2 public class Swagger2 { //配置swagger2核心配置 @Bean public Docket createRestApi(){ return new Docket(DocumentationType.SWAGGER_2) //指定api类型位swagger2 .apiInfo(apiInfo()) //用于定义api文档汇总信息 .select() //.apis(RequestHandlerSelectors.basePackage("com.liud.demo.controller")) //指定生成文档的controller //.apis(RequestHandlerSelectors.any()) //为任何接口生成API文档 //.apis(RequestHandlerSelectors.withClassAnnotation(Api.class)) //为有@Api注解的Controller生成API文档 .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)) //为有@ApiOperation注解的方法生成API文档 .paths(PathSelectors.any()) .build(); } //api基本信息 private ApiInfo apiInfo(){ return new ApiInfoBuilder() .title("SpringBootDemo的项目接口API") //文档标题 .contact(new Contact("liud", //作者 "", "")) //联系人 .description("SpringBootDemo的项目接口API")//详细信息 .version("1.0.0")//文档版本号 .termsOfServiceUrl("")//网站地址 .build(); } }

Controller

package com.liud.demo.controller; import com.liud.demo.service.HelloService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.*; import javax.servlet.{ip}:{port}/swagger-ui.html#/

我的地址:127.0.0.1:8081/swagger-ui.html

②文档模式

在浏览器上输入url:
{ip}:{port}/doc.html

我的地址:127.0.0.1:8081/doc.html

第三部分 swagger2常用注解

常用注解:

@Api()用于类;
表示标识这个类是swagger的资源
tags–表示说明
value–也是说明,可以使用tags替代
但是tags如果有多个值,会生成多个list


效果:

如何详细编写SpringBoot整合Swagger2生成在线API文档的代码?

@ApiOperation()用于方法;
表示一个http请求的操作
value用于方法描述
notes用于提示内容
tags可以重新分组(视情况而用)

@ApiParam()用于方法,参数,字段说明;
表示对参数的添加元数据(说明或是否必填等)
name–参数名
value–参数说明
required–是否必填

@ApiParam(name="username",value = "用户名",required = true) String username

效果:

  • @ApiModel()用于类
  • 表示对类进行说明,用于参数用实体类接收
  • @ApiModelProperty()用于方法,字段
  • 表示对model属性的说明或者数据操作更改
  • @ApiIgnore()用于类,方法,方法参数
  • 表示这个方法或者类被忽略
  • @ApiImplicitParam() 用于方法
  • 表示单独的请求参数
  • @ApiImplicitParams() 用于方法,包含多个@ApiImplicitParam

到此这篇关于SpringBoot集成Swagger2构建在线API文档的文章就介绍到这了,更多相关SpringBoot集成Swagger2内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!