赞
踩
一般来说,接口文档是需要咱们后台开发人员来提供的,或者架构师,接口文档的形式有许多种,任何形式都是可以的。例如
那么就出现了一个问题:如上所示需要开发人员 编写接口文档岂不是很累?要写许多的请求路径 和参数 以及示例值,工作强度大,时间耗费,所以我们开发人员可使用一些程序帮我们一键生成接口文档,那么这个技术可以使用:swagger 以及升级版的knife4j 后面我们会使用到。
接口文档必须包含:
(1)简介
Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务(https://swagger.io/)。 它的主要作用是:
使得前后端分离开发更加方便,有利于团队协作
接口的文档在线自动生成,降低后端开发人员编写接口文档的负担
功能测试
Spring已经将Swagger纳入自身的标准,建立了Spring-swagger项目,现在叫Springfox。通过在项目中引入Springfox ,即可非常简单快捷的使用Swagger。
(2)SpringBoot集成Swagger
引入依赖,在【itheima-leadnews】模块中引入该依赖
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.9.2</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.9.2</version>
</dependency>
在工程的config包中添加一个配置类
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; import java.util.HashSet; @Configuration @EnableSwagger2 public class SwaggerConfiguration { @Bean public Docket buildDocket() { HashSet<String> strings = new HashSet<>(); strings.add("application/json"); return new Docket(DocumentationType.SWAGGER_2) .apiInfo(buildApiInfo()) //设置返回值数据类型为json .produces(strings) .select() // 要扫描的API(Controller)基础包 .apis(RequestHandlerSelectors.basePackage("com.leannews")) .paths(PathSelectors.any()) .build(); } private ApiInfo buildApiInfo() { Contact contact = new Contact("Zengfl","",""); return new ApiInfoBuilder() .title("xxx系统-平台管理API文档") .description("平台管理服务api") .contact(contact) .version("1.0.0").build(); } }
启动工程后访问:http://localhost:9001/swagger-ui.html
(3)Swagger常用注解
@Api:修饰整个类,描述Controller的作用
@ApiOperation:修饰类的一个方法 标识 操作信息 接口的定义
@ApiParam:单个参数的描述信息
@ApiModel:描述使用到的对象信息
@ApiModelProperty:描述使用到的对象的属性信息
@ApiResponse:HTTP响应其中1个描述
@ApiResponses:HTTP响应整体描述
@ApiIgnore:使用该注解忽略这个API
@ApiError :发生错误返回的信息
@ApiImplicitParam:一个请求参数
@ApiImplicitParams:多个请求参数的描述信息
@ApiImplicitParam属性:
属性 | 取值 | 作用 |
---|---|---|
paramType | 查询参数类型 | |
path | 以地址的形式提交数据 | |
query | 直接跟参数完成自动映射赋值 | |
body | 以流的形式提交 仅支持POST | |
header | 参数在request headers 里边提交 | |
form | 以form表单的形式提交 仅支持POST | |
dataType | 参数的数据类型 只作为标志说明,并没有实际验证 | |
Long | ||
String | ||
name | 接收参数名 | |
value | 接收参数的意义描述 | |
required | 参数是否必填 | |
true | 必填 | |
false | 非必填 | |
defaultValue | 默认值 |
https://blog.csdn.net/ThinkWon/article/details/107477801
我们在controller中添加Swagger注解,代码如下所示:
@Api(tags = "频道管理")
public class AdChannelController {
}
在vo,dto或实体类中添加api相关注解:
import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; import java.io.Serializable; @Data @ApiModel(value="PageRequestDto", description="通用分页查询参数") public class PageRequestDto implements Serializable { @ApiModelProperty(notes = "每页大小", dataType="Long") private Long size; @ApiModelProperty(notes = "页码", dataType="Long") private Long page; public void checkParam() { if (this.page == null || this.page < 0) { setPage(1l); } if (this.size == null || this.size < 0 || this.size > 100) { setSize(10l); } } }
启动微服务,访问地址:http://localhost:9001/swagger-ui.html
官方的注解说明如下:
https://github.com/swagger-api/swagger-core/wiki/Annotations-1.5.X
(1)简介
knife4j是为Java MVC框架集成Swagger生成Api文档的增强解决方案,前身是swagger-bootstrap-ui,取名kni4j是希望它能像一把匕首一样小巧,轻量,并且功能强悍!
gitee地址:https://gitee.com/xiaoym/knife4j
官方文档:https://doc.xiaominfo.com/
效果演示:http://knife4j.xiaominfo.com/doc.html
(2)核心功能
该UI增强包主要包括两大核心功能:文档说明 和 在线调试
(3)快速集成
文件中引入
knife4j的依赖,并【删除掉原来的swagger的依赖】如下:<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>knife4j-spring-boot-starter</artifactId>
</dependency>
注意,如果是高版本springboot已经去除掉了validation 还需要在工程中添加依赖,因为knife4j需要使用到他
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
以上有两个注解需要特别说明,如下表:
注解 | 说明 |
---|---|
@EnableSwagger2 | 该注解是Springfox-swagger框架提供的使用Swagger注解,该注解必须加 |
@EnableKnife4j | 该注解是knife4j 提供的增强注解,Ui提供了例如动态参数、参数过滤、接口排序等增强功能,如果你想使用这些增强功能就必须加该注解,否则可以不用加 |
修改AdChannelController添加Api说明
添加好了后就可以启动微服务啦,然后通过地址访问,下载接口文档,也可以在此页面调试功能,very good!
在浏览器输入地址:http://localhost:9001/doc.html
如图所示:
如此就可以在文档管理功能里面下载离线文档发给前端,
还可以在自定义的如【频道管理】进行功能调试,这样就不需要postman这个工具了
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。