关于 Swagger
Swagger 是一个 RESTful 接口文档的规范和工具集,它的目标是统一 RESTful 接口文档的格式和规范。在开发过程中,接口文档是非常重要的一环,它不仅方便开发者查看和理解接口的功能和参数,还能帮助前后端开发协同工作,提高开发效率。在 Spring Boot 中,我们可以通过集成 Swagger 来实现接口文档的自动生成。Swagger 通过注解来描述接口,然后根据这些注解自动生成接口文档。
Swagger 的使用
编写接口
在编写接口时,我们需要使用 Swagger 的注解来描述接口信息。常用的注解包括:
@Api:用于描述接口的类或接口
@ApiOperation:用于描述接口的方法
@ApiParam:用于描述接口的参数
@ApiModel:用于描述数据模型
@ApiModelProperty:用于描述数据模型的属性
例如,我们编写一个简单的接口:
@RestController
@Api(tags = "用户接口")
public class UserController {
@GetMapping("/user/{id}")
@ApiOperation(value = "根据 ID 获取用户信息")
public User getUserById(@ApiParam(value = "用户 ID", required = true) @PathVariable Long id) {
// 根据 ID 查询用户信息
}
}
在上面的代码中,@Api表示该类是一个用户接口,@ApiOperation 表示该方法是获取用户信息的接口,@ApiParam 表示该参数是用户 ID,@PathVariable 表示该参数是路径参数。
启用 Swagger
在 Spring Boot 中,我们可以通过添加 Swagger 相关的依赖来启用 Swagger。
我们可以在 pom.xml 文件中添加以下依赖:
<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>
美化版ui,第三方,按需要加
<!--doc.html -->
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>swagger-bootstrap-ui</artifactId>
<version>1.9.2</version>
</dependency>
创建SwaggerConfig类,加上注释就开启了,使用默认配置
@Configuration
@EnableSwagger2
public class SwaggerConfig {
}
在上面的代码中,@Configuration 表示该类是一个配置类,@EnableSwagger2 表示启用 Swagger
查看接口文档
启动 Spring Boot 应用后,我们可以在浏览器中访问 http://localhost:8080/swagger-ui.html 来查看接口文档。
美化版地址是:http://localhost:8080/doc.html
在 Swagger UI 页面中,我们可以看到所有的接口信息,包括接口名称、请求方式、请求路径、请求参数、响应参数等。