Swagger
首先 使用@EnableSwagger2
使项目开启swagger功能
apinfo用于配置文档的基本信息
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("自媒体接口API")
.contact(new Contact("Lyra",
"https://www.cnblogs.com/lyraHeartstrings/",
"365373011@qq.com"))
.description("自媒体平台提供的API文档")
.version("1.0.0")
// 网站地址
.termsOfServiceUrl("https://www.cnblogs.com/lyraHeartstrings/")
.build();
}
swagger 配置
public Docket docket() {
Predicate<RequestHandler> adminPredicate = RequestHandlerSelectors.basePackage("com.lyra.admin.controller");
Predicate<RequestHandler> articlePredicate = RequestHandlerSelectors.basePackage("com.lyra.article.controller");
Predicate<RequestHandler> userPredicate = RequestHandlerSelectors.basePackage("com.lyra.api.user.controller");
Predicate<RequestHandler> filesPredicate = RequestHandlerSelectors.basePackage("com.lyra.files.controller");
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(this.apiInfo())
.select()
// 扫描 api 包
.apis(Predicates.or(adminPredicate, articlePredicate, userPredicate, filesPredicate))
// controller 路径 any为任何路径
.paths(PathSelectors.any())
.build();
}
@Api
用于配置在类上 描述类作用
@Api(value = "controller标题", tags = {"xxx"})
@ApiOperation
配置在类方法中 描述防腐作用
@ApiOperation(value = "hello方法测试", notes = "hello方法测试", httpMethod = "GET")
swagger配置在api模块中的好处
可以解耦合 只用配置一次 别的类中 和 用于解耦合 当类中的业务代码更改后不用修改 将接口与实现了解耦合
虽然道路是曲折的,但前途是光明的。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律