news 2026/4/23 11:25:00

SpringBoot配置Swagger

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SpringBoot配置Swagger

目录

  • 一、Swagger介绍
    • 1、什么是Swagger
    • 2、为什么使用 Swagger?
  • 二、Swagger常用注解
    • 1、@Api
    • 2、@ApiModel
    • 3、@ApiModelProperty
    • 4、@ApiOperation
  • 三、SpringBoot中配置Swagge
    • 1、引入依赖
    • 2、使用方式
  • 四、验证Swagger配置

一、Swagger介绍

1、什么是Swagger

定义
OpenAPI 规范:描述 RESTful API 的标准格式(JSON/YAML)
Swagger 工具集:围绕 OpenAPI 规范构建的工具集合

2、为什么使用 Swagger?

优势
标准化文档 - 统一的 API 描述格式
交互式测试 - 直接在浏览器测试 API
前后端协作 - 基于文档先行开发
代码自动生成 - 减少手写代码
API 管理 - 版本控制、权限管理

二、Swagger常用注解

通过注解可以控制生成的接口文档,使接口文档拥有更好的可读性,常用注解如下:

1、@Api

@Api用在类上,例如Controller,表示对类的说明

@Api(tags="员工管理")@RestController@RequestMapping("/admin/employee")@Slf4jpublicclassEmployeeController{

2、@ApiModel

@ApiModel用在类上,例如entity、DTO、VO,配合@APIModelProperty使用

@Data@Builder@NoArgsConstructor@AllArgsConstructor@ApiModel("员工信息")publicclassEmployeeimplementsSerializable{privatestaticfinallongserialVersionUID=1L;@ApiModelProperty("员工id")privateLongid;@ApiModelProperty("用户名")privateStringusername;privateStringname;privateStringpassword;privateStringphone;privateStringsex;privateStringidNumber;privateIntegerstatus;// @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")privateLocalDateTimecreateTime;// @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")privateLocalDateTimeupdateTime;privateLongcreateUser;privateLongupdateUser;}

3、@ApiModelProperty

@ApiModelProperty用在属性上,描述属性信息

@Data@Builder@NoArgsConstructor@AllArgsConstructor@ApiModel("员工信息")publicclassEmployeeimplementsSerializable{privatestaticfinallongserialVersionUID=1L;@ApiModelProperty("员工id")privateLongid;@ApiModelProperty("用户名")privateStringusername;privateStringname;privateStringpassword;privateStringphone;privateStringsex;privateStringidNumber;privateIntegerstatus;// @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")privateLocalDateTimecreateTime;// @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")privateLocalDateTimeupdateTime;privateLongcreateUser;privateLongupdateUser;}

4、@ApiOperation

@ApiOperation用在方法上,例如Controller的方法,说明方法的用途、作用

@PostMapping("/login") @ApiOperation("员工登录") public Result<EmployeeLoginVO>login(@RequestBody EmployeeLoginDTO employeeLoginDTO) { log.info("员工登录:{}", employeeLoginDTO); Employee employee = employeeService.login(employeeLoginDTO); //登录成功后,生成jwt令牌 Map<String,Object>claims = new HashMap<>(); claims.put(JwtClaimsConstant.EMP_ID, employee.getId()); String token = JwtUtil.createJWT( jwtProperties.getAdminSecretKey(), jwtProperties.getAdminTtl(), claims); EmployeeLoginVO employeeLoginVO = EmployeeLoginVO.builder() .id(employee.getId()) .userName(employee.getUsername()) .name(employee.getName()) .token(token) .build(); return Result.success(employeeLoginVO); }

三、SpringBoot中配置Swagge

rKnife4j 是为Java MVC框架集成Swagger生成Api文档的增强解决方案。

1、引入依赖

<dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-spring-boot-starter</artifactId><version>3.0.2</version></dependency>

2、使用方式

1、导入 knife4j 的maven坐标

<dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-spring-boot-starter</artifactId><version>3.0.2</version></dependency>

2、在配置类中加入 knife4j 相关配置

@Configuration@Slf4jpublicclassWebMvcConfigurationextendsWebMvcConfigurationSupport{/** * 通过knife4j生成接口文档 * @return */@BeanpublicDocketdocket(){ApiInfoapiInfo=newApiInfoBuilder().title("项目接口文档").version("2.0").description("苍穹外卖项目接口文档介绍").build();Docketdocket=newDocket(DocumentationType.SWAGGER_2).apiInfo(apiInfo).select().apis(RequestHandlerSelectors.basePackage("com.sky.controller")).paths(PathSelectors.any()).build();returndocket;}

3、设置静态资源映射,否则接口文档页面无法访问

protectedvoidaddResourceHandlers(ResourceHandlerRegistryregistry){registry.addResourceHandler("/doc.html").addResourceLocations("classpath:/META-INF/resources/");registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");}

接口文档访问路径为http://ip:port/doc.html

四、验证Swagger配置


title(“项目接口文档”)对应

description(“苍穹外卖项目接口文档介绍”)对应



接口口调试方法:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 13:52:36

Aviator预测助手实战指南:5步掌握数据驱动决策

在Aviator游戏中&#xff0c;你是否经常在起飞时机上犹豫不决&#xff1f;数据驱动的预测工具能显著提升你的决策质量。本文将详细介绍如何通过在线助手获取实时预测信号&#xff0c;建立有效的游戏策略体系。读完本文&#xff0c;你将掌握从基础配置到高级策略的全套实战技能。…

作者头像 李华
网站建设 2026/4/16 0:26:11

腾讯混元3D-Part完全上手指南:从零开始掌握3D部件生成技术

腾讯混元3D-Part完全上手指南&#xff1a;从零开始掌握3D部件生成技术 【免费下载链接】Hunyuan3D-Part 腾讯混元3D-Part 项目地址: https://ai.gitcode.com/tencent_hunyuan/Hunyuan3D-Part 对于想要进入3D内容创作领域的新手来说&#xff0c;腾讯混元3D-Part提供了一个…

作者头像 李华
网站建设 2026/4/18 18:09:22

C语言:数据库内核开发的隐形冠军

C语言&#xff1a;数据库内核开发的隐形冠军 【免费下载链接】db_tutorial db_tutorial&#xff1a;这是一个数据库教程项目&#xff0c;旨在帮助开发者学习和掌握数据库的基本知识和技能。这个项目稳健性强&#xff0c;可以抵御多变的开发环境并自我恢复。 项目地址: https:…

作者头像 李华
网站建设 2026/4/18 14:34:32

突破性架构如何实现大模型推理的3倍性能飞跃?

突破性架构如何实现大模型推理的3倍性能飞跃&#xff1f; 【免费下载链接】inference Replace OpenAI GPT with another LLM in your app by changing a single line of code. Xinference gives you the freedom to use any LLM you need. With Xinference, youre empowered to…

作者头像 李华
网站建设 2026/4/18 15:20:19

21、Linux 打印机、扫描仪使用及多语言支持全攻略

Linux 打印机、扫描仪使用及多语言支持全攻略 打印机墨水及维护功能 若现有工具无法查看打印机墨水水平和维护功能,或者打印机品牌未被列出,可尝试使用制造商提供的 Linux 驱动程序(若有)。部分新型打印机可通过机身上的控制按钮来检查墨水水平、对齐和清洁墨盒。若有疑问…

作者头像 李华
网站建设 2026/4/21 14:07:17

RPCS3模拟器汉化补丁完全配置指南:轻松实现中文游戏体验

RPCS3模拟器汉化补丁完全配置指南&#xff1a;轻松实现中文游戏体验 【免费下载链接】rpcs3 PS3 emulator/debugger 项目地址: https://gitcode.com/GitHub_Trending/rp/rpcs3 想要在PC上畅玩中文版PS3经典游戏&#xff1f;RPCS3模拟器通过强大的补丁系统让语言障碍成为…

作者头像 李华