Swagger
1.在springboot 2.1.0release 版本下:
swagger2版本
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.6.1</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.6.1</version>
</dependency>
2.主要配置类:
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;
/**
* @author:Frankiegg
* @date:2018/9/12
* @project:bee
* @Modified By:
**/
@Configuration
@EnableSwagger2
public class Swagger2 {
@Bean
public Docket createRestApi() {
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(apiInfo())
.select()
//为当前包路径
.apis(RequestHandlerSelectors.basePackage("com.sinosoft.sss"))
.paths(PathSelectors.any())
.build();
}
//构建 api文档的详细信息函数,注意这里的注解引用的是哪个
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
//页面标题
.title("开放式销售平台回访查询模块接口文档")
//创建人
.contact(new Contact("Frankiegg", "http://www.baidu.com", ""))
//版本号
.version("1.0")
//描述
.description("包括回访查询接口和保单详情查询接口")
.build();
}
}
3.主要使用方式
Swagger 是一个用于构建、文档化和测试 RESTful API 的强大工具。下面是一些常用的 Swagger 注解和使用示例:
@Api
:用于声明一个控制器类为 Swagger 文档的一部分。
@Api(tags = "User API", description = "Operations related to users")
@RestController
@RequestMapping("/api/users")
public class UserController {
// ...
}
@ApiOperation
:用于描述一个操作或接口。
@ApiOperation(value = "Get user by ID", response = User.class)
@GetMapping("/{id}")
public User getUserById(@PathVariable Long id) {
// ...
}
@ApiParam
:用于给操作的参数添加描述。
@GetMapping("/{id}")
public User getUserById(@ApiParam(value = "User ID", required = true) @PathVariable Long id) {
// ...
}
@ApiResponse
:用于描述一个操作的返回结果。
@ApiResponse(code = 200, message = "Success", response = User.class)
@GetMapping("/{id}")
public User getUserById(@PathVariable Long id) {
// ...
}
@ApiResponses
:用于描述一组操作的返回结果。
@ApiResponses(value = {
@ApiResponse(code = 200, message = "Success", response = User.class),
@ApiResponse(code = 404, message = "User not found")
})
@GetMapping("/{id}")
public User getUserById(@PathVariable Long id) {
// ...
}
@ApiModel
:用于描述一个数据模型。
@ApiModel(description = "User create request")
public class CreateUserRequest {
// ...
}
@ApiModelProperty
:用于给数据模型的属性添加描述。
@ApiModel(description = "User")
public class User {
@ApiModelProperty(value = "User ID", example = "123", required = true)
private Long id;
// ...
}
以上只是 Swagger 注解的一小部分,还有更多可用于定制化和文档编写的注解。详细的注解用法和示例可以查看 Swagger 官方文档。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?