用 Swagger 实现接口文档
创作时间:
作者:
@小白创作中心
用 Swagger 实现接口文档
引用
CSDN
1.
https://blog.csdn.net/Be_racle/article/details/140413932
《接口设计》系列,共包含以下 5 篇文章:
- 前后端的通信方式 REST
- 如何设计统一 RESTful 风格的数据接口
- 为 APP、PC、H5 网页提供统一风格的 API(实战篇,附源码地址)
- 用 Swagger 实现接口文档
- 学会用 RestTemplate 发请求
在项目开发中,一般都是由前后端工程师共同定义接口,编写接口文档,之后大家根据这个接口文档进行开发、维护。为了便于编写和维护稳定,可以使用 Swagger 来编写 API 接口文档,以提升团队的沟通效率。
下面演示如何在 Spring Boot 中集成 Swagger。
1.配置 Swagger
1.1 添加 Swagger 依赖
<!--Swagger依赖-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.9.2</version>
</dependency>
<!--Swagger-UI依赖 -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.9.2</version>
</dependency>
1.2 创建 Swagger 配置类
创建 Swagger 配置类,完成相关配置项,见以下代码:
package com.example.demo.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
/**
* Swagger 配置类
* 在与 Spring Boot 集成时,放在与 Application.java 同级的目录下
*/
@Configuration
@EnableSwagger2
public class SwaggerConfig {
/**
* 创建 API 应用
* 本例采用指定扫描的包路径来定义指定要建立 API 的目录
*/
@Bean
public Docket createRestApi() {
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(apiInfo())
.select()
.apis(RequestHandlerSelectors.basePackage("com.example.demo.controller"))
.paths(PathSelectors.any())
.build();
}
/**
* 创建该 API 的基本信息(这些基本信息会展现在文档页面中)
* 访问地址:http://项目实际地址/swagger-ui.html
*/
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title(" RESTful APIs")
.description("RESTful APIs")
.termsOfServiceUrl("http://localhost:8080/")
.contact("pipi")
.version("1.0")
.build();
}
}
@Configuration
:让 Spring 来加载该类配置。@EnableSwagger2
:启用 Swagger2。createRestApi
函数创建 Docket 的 Bean。apiInfo()
:用来展示该 API 的基本信息。select()
:返回一个 ApiSelectorBuilder 实例,用来控制哪些接口暴露给 Swagger 来展现。apis(RequestHandlerSelectors.basePackage())
:配置包扫描路径。Swagger 会扫描包下所有 Controler 定义的 API,并产生文档内容。如果不想产生 API,则使用注解@ApiIgnore
。
2.编写接口文档
在完成上述配置后,即生成了文档,但是这样生成的文档主要针对请求本身,而描述自动根据方法等命名产生,对用户并不友好。所以,通常需要自己增加一些说明以丰富文档内容。可以通过以下注解来增加说明。
@Api
:描述类/接口的主要用途。@ApiOperation
:描述方法用途,给 API 增加说明。@ApiImplicitParam
:描述方法的参数,给参数增加说明。@ApiImplicitParams
:描述方法的参数(Multi-Params),给参数增加说明。@ApiIgnore
:忽略某类/方法/参数的文档。
具体使用方法见以下代码:
package com.example.demo.controller;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiOperation;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.annotations.ApiIgnore;
@RestController
public class HelloWorldController {
@ApiOperation(value = "hello", notes = "notes")
@RequestMapping("/hello")
public String hello() throws Exception {
return "HelloWorld ,Spring Boot!";
}
// 使用该注解忽略这个 API
@ApiIgnore
@RequestMapping(value = "/ignoreApi")
public String ignoreApi() {
return "HelloWorld ,Spring Boot!";
}
}
完成上述代码后,启动项目,访问 http://localhost:8080/swagger-ui.html 就能看到所展示的 RESTful API 的页面,可以通过单击具体的 API 测试请求,来查看代码中配置的信息,以及参数的描述信息。
热门推荐
全科医生应具备的基本能力有哪些
盐酸西替利嗪片
得了痔疮不用管?这个被“小小痔疮”威胁生命的27岁小伙有话说!
从炼气到人仙:用科学公式和数学模型解析修仙体系的能量进化
探究燕窝腥臭味的成因及去除方法:全面解析燕窝品质问题与处理技巧
藿香正气散治疗腹泻新突破:调节肠道菌群与消化酶活性
藿香正气散是不是 “解暑药”?
网上交易平台如何挣钱:法律视角下的商业模式与合规路径
离婚冷静期内的纠纷解决指南
CSP-J/S认证考试数据解读报告:满分有多难?
欠款案件:物业管理纠纷中的法律适用与解决方案
发生纠纷时的法律条款:理解和运用关键条款解决争议
牛奶选购指南:种类、人群适用与保存方法全解析
钠与水反应现象及解释
揭秘朝鲜第四大城市新义州:与丹东形成鲜明对比
提高雅思口语能力的有效方法:多积累口语素材、多模拟练习
学生如何用好人工智能
公卫中心多学科合作诊治嗜铬细胞瘤
MySQL未提交事务导致的TRUNCATE表阻塞挂起问题处理
螃蟹有几条腿?
螃蜞和螃蟹的区别
春天动物有什么?春天的动物乐园:唤醒沉睡的精灵们!
苏州戏院巡礼:承载老苏州文化记忆的城市符号!
2025年开年,北京楼市热度能持续吗?
如何准确评估二手房价格
密歇根大学MSI项目全解析:课程设置、申请要求与就业前景
如何判断插座的质量与安全性?这种判断如何保障用电安全?
如何有效进行软件开发项目需求分析?
基于深度学习的人脸情绪识别检测技术详解
氧化铁颜料的生产工艺