Spring Boot 中如何使用 Swagger

news2025/1/11 7:39:28

在 Spring Boot 中使用 Swagger

介绍

在开发 Web 应用时,API 文档的编写和维护是一项非常重要的工作。Swagger 是一款非常流行的 API 文档工具,可以自动生成 API 文档,并提供一系列的交互式工具,如测试界面、调试界面等,方便开发者进行 API 的调试和测试。本文将介绍如何在 Spring Boot 应用中使用 Swagger。

在这里插入图片描述

引入依赖

首先需要在 pom.xml 文件中引入 Swagger 的依赖:

<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>

上述依赖中,springfox-swagger2 是 Swagger 的核心库,提供了 API 文档的生成和管理功能;springfox-swagger-ui 则提供了 Swagger 的用户界面,包括交互式测试工具、调试工具等。

配置 Swagger

接下来需要在 Spring Boot 应用中配置 Swagger。可以通过添加一个 SwaggerConfig 类来配置 Swagger。以下是一个简单的 SwaggerConfig 配置示例:

@Configuration
@EnableSwagger2
public class SwaggerConfig {
 
    @Bean
    public Docket api() {
        return new Docket(DocumentationType.SWAGGER_2)
                .select()
                .apis(RequestHandlerSelectors.basePackage("com.example.demo"))
                .paths(PathSelectors.any())
                .build()
                .apiInfo(apiInfo());
    }
 
    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("API 文档")
                .description("这是一个 Swagger API 文档示例")
                .version("1.0.0")
                .build();
    }
 
}

上述配置中,@EnableSwagger2 注解表示启用 Swagger 功能。Docket 类表示一个 API 文档配置,可以设置 API 文档的基本信息和请求接口的过滤条件。在上述示例中,设置了 API 文档的基本信息和请求接口的过滤条件,包括 API 文档的标题、描述、版本号等信息,以及过滤掉不需要生成 API 文档的请求接口。

使用 Swagger

在 Spring Boot 应用中使用 Swagger 非常简单,只需要在需要生成 API 文档的方法上添加相应的注解即可。以下是常用的 Swagger 注解:

  • @Api:表示一个 API 接口的基本信息,包括标题、描述、版本号等信息。
  • @ApiOperation:表示一个 API 接口的详细信息,包括请求方法、请求路径、请求参数、请求体、响应信息等。
  • @ApiParam:表示一个 API 接口的请求参数信息。
  • @ApiModel:表示一个 API 接口的请求或响应模型信息。
  • @ApiModelProperty:表示一个 API 接口的请求或响应模型属性信息。

以下是一个示例代码,演示如何在 Spring Boot 应用中使用 Swagger:

@RestController
@Api(tags = "用户管理")
public class UserController {
 
    @Autowired
    private UserService userService;
 
    @ApiOperation(value = "获取用户信息", notes = "根据用户 ID 获取用户信息")
    @ApiImplicitParam(name = "id", value = "用户 ID", dataType = "Long", required = true)
    @GetMapping("/user/{id}")
    public User getUserById(@PathVariable Long id) {
        return userService.getUserById(id);
    }
 
    @ApiOperation(value = "创建用户", notes = "创建一个新的用户")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "username", value = "用户名", dataType = "String", required = true),
            @ApiImplicitParam(name = "password", value = "密码", dataType = "String", required = true)
    })
    @PostMapping("/user")
    public User createUser(@RequestParam String username, @RequestParam String password) {
        return userService.createUser(username, password);
    }
 
}

在上述示例中,使用 @Api 注解标记了 UserController类,并指定了一个标签 “用户管理”。在 getUserById 方法和 createUser 方法中,分别使用了 @ApiOperation 注解标记了方法的详细信息,包括请求方法、请求路径、请求参数、请求体、响应信息等。同时使用了 @ApiImplicitParam 注解标记了请求参数的信息,包括参数名、参数类型、是否必须等。这些注解可以帮助 Swagger 自动生成 API 文档,并提供交互式测试工具。

使用 Swagger UI

在应用启动后,可以通过访问 http://localhost:8080/swagger-ui.html 地址来打开 Swagger UI 界面。在 Swagger UI 界面中,可以看到生成的 API 文档,并提供了一系列的交互式工具,如测试界面、调试界面等,方便开发者进行 API 的调试和测试。

结语

本文介绍了如何在 Spring Boot 应用中使用 Swagger,包括引入依赖、配置 Swagger、使用 Swagger 注解和使用 Swagger UI 界面。Swagger 可以帮助开发者快速生成 API 文档,并提供一系列的交互式工具,方便开发者进行 API 的调试和测试。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/688105.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在线选座票务系统开发 座位预先选出行更方便

我们平时去影院剧场观看电影演出的时候&#xff0c;去早了要等很久才开始&#xff0c;去晚了好座位都被别人占了&#xff0c;自己只能挤在角落里&#xff0c;影响观感体验。影院剧场在线选座APP小程序系统开发就很好的解决了这一问题&#xff0c;可以满足用户在线订座、在线选座…

【动态规划算法练习】day6

文章目录 一、53. 最大子数组和1.题目简介2.解题思路3.代码4.运行结果 二、918. 环形子数组的最大和1.题目简介2.解题思路3.代码4.运行结果 三、152. 乘积最大子数组1.题目简介2.解题思路3.代码4.运行结果 总结 一、53. 最大子数组和 1.题目简介 53. 最大子数组和 给你一个整…

【Java】Java 纪录类(Record Class)及代码示例

本文仅供学习交流使用&#xff01; Java Record Class相关文章地址&#xff1a; https://www.liaoxuefeng.com/wiki/1252599548343744/1331429187256353 https://www.baeldung.com/java-record-keyword https://www.developer.com/java/java-record-class/ Java中的记录类是什么…

SSMP整合案例(7) MybatisPlus快速service业务层开发

上文 SSMP整合案例(6) 业务service层逻辑编写我们创建并编写了service业务层代码 但是 这样一个一个去写 确实是有点麻烦 重复性工作 但其实这个已经有人帮我们考虑好了 MP就帮我们做了一个 service快捷开发的方式 我们在项目中的service包下创建一个接口 叫 IBookService 其实…

fscan安装以及使用

windows安装 1.go语言下载。 下载msi版本&#xff0c;直接安装就可以不用配置环境变量&#xff0c;默认是帮你安装配合好的 https://go.dev/dl/ 2.配置go环境 使用默认配置的话&#xff0c;下载速度过慢&#xff0c;导致无法完成编译。故需要配置代理。 在cmd命令行中…

RocketMQ --- 基础篇

一、MQ介绍 1.1、为什么要用MQ 消息队列是一种“先进先出”的数据结构 其应用场景主要包含以下3个方面 1.1.1、应用解耦 系统的耦合性越高&#xff0c;容错性就越低。以电商应用为例&#xff0c;用户创建订单后&#xff0c;如果耦合调用库存系统、物流系统、支付系统&…

Shapley值法介绍及实例计算

Shapley值法介绍及实例计算 为解决多个局中人在合作过程中因利益分配而产生矛盾的问题,属于合作博弈领域。应用 Shapley 值的一大优势是按照成员对联盟的边际贡献率将利益进行分配,即成员 i 所分得的利益等于该成员为他所参与联盟创造的边际利益的平均值。 本文从Shapl…

【裸机开发】EPIT 定时器 —— 按键消抖

实际工程中&#xff0c;不能直接通过延时来消抖 ! 这里我们采用定时器来消抖&#xff0c;这也是内核处理消抖的一种方式。 目录 一、基本原理 1、延时消抖的弊端 2、定时器消抖原理 二、按键消抖实现 1、按键中断 2、定时器中断 三、附加&#xff1a;按键 / 定时器中断初…

熊哥保佑你 计算机组成原理复习

移码是符号位取反 . . Cache——主存地址映像&#xff1a; 全相联&#xff1a;块号字块内地址 直接映射&#xff1a;标记行号字块内地址 组相联&#xff1a;标记组号字块内地址 一个单元一个字节 2路组相联&#xff1a; 全相联&#xff1a; 直接映射&#xff1a; . …

代码随想录算法训练营第四十七天| 198.打家劫舍、 213.打家劫舍II 、 337.打家劫舍III

打家劫舍 题目链接&#xff1a;力扣 确定dp数组&#xff08;dp table&#xff09;以及下标的含义 dp[i]&#xff1a;截至到i位置的房屋&#xff0c;最多可以偷窃的金额为dp[i]。确定递推公式 决定dp[i]的关键因素就是第i房间偷还是不偷。如果偷第i房间&#xff0c;那么dp[i] …

Ceph分布式存储系统搭建

目录 安装部署示例 &#xff08;一&#xff09;准备环境 1). 设置主机名 2). 关闭防火墙 3).添加sdb磁盘并格式化 4).配置hosts解析文件 5).配置免密登录 6).同步时区 7). 安装 Ceph 包 &#xff08;二&#xff09;创建 Ceph 集群 1、 安装ceph-deploy管理工具 2、 …

【C++】STL——string类的基本介绍、string常见的使用、string类的接口说明、string类的容量操作

文章目录 1.C语言的字符串2.C标准库中的string类2.1string类2.2string类的常用接口说明2.3string类对象的容量操作 1.C语言的字符串 在C语言中&#xff0c;字符串被表示为字符数组。C语言中的字符串以’\0’字符&#xff08;null字符或字符串结束符&#xff09;结尾&#xff0c…

了解 Splashtop 的多层安全防护措施

随着技术的进步&#xff0c;如何确保数据安全也越来越重要。Splashtop 作为行业领先的远程访问软件供应商&#xff0c;对这一点非常了解。Splashtop 基于信任、客观性、监控和隐私搭建安全框架&#xff0c;致力于保护所有数据交互和用户设备。 了解 Splashtop 安全性的核心 S…

图像色彩增强相关论文阅读-Representative Color Transform for Image Enhancement(ICCV2021)

文章目录 Representative Color Transform for Image EnhancementAbstractIntroductionRelated workMethod实验Conclusion Representative Color Transform for Image Enhancement 作者&#xff1a;Hanul Kim1, Su-Min Choi2, Chang-Su Kim3, Yeong Jun Koh 单位&#xff1a;S…

MySQL调优系列(八)——事务和锁分类

一、事务是什么 事务是逻辑上的一组操作&#xff0c;要么都执行&#xff0c;要么都不执行。 sql语句如下&#xff1a; # 开启事务 START TRANSACTION; # 多条 SQL 语句 SQL1,SQL2... ## 提交事务 COMMIT;二、事务的特性&#xff08;ACID&#xff09; 原子性&#xff08;Atom…

线上商城开发都有哪些方法?费用多少

随着如今网络环境的愈发成熟&#xff0c;人们的消费习惯开始逐渐向线上迁移&#xff0c;为了能满足此种需求&#xff0c;企业商家都开始了线上商城的建设&#xff0c;希望能借助网络的力量促进自身的发展&#xff0c;创造更高的盈利空间&#xff0c;那么如何搭建一个线上商城呢…

Zookeeper 从安装到应用

博主介绍&#xff1a; ✌博主从事应用安全和大数据领域&#xff0c;有8年研发经验&#xff0c;5年面试官经验&#xff0c;Java技术专家✌ Java知识图谱点击链接&#xff1a;体系化学习Java&#xff08;Java面试专题&#xff09; &#x1f495;&#x1f495; 感兴趣的同学可以收…

GPIO模拟时序控制外设3——AT24C02

文章目录 前言AT24C02简介引脚介绍器件寻址寻址流程器件地址的组成其他I2C器件的地址组成 通信流程1.完整的传输过程2.初始化管脚3.起始信号4.停止信号5.MCU发送8位数据5.MCU接收应答位6.MCU接收八位数据7.MCU发送应答位 AT24C02写一个字节AT24C02读一个字节实现的效果 总结 前…

如何利用VS打包C++程序

如何将VS开发的C程序打包发给别人使用呢&#xff1f;话不多说&#xff0c;跟随以下步骤即可完成&#xff1a; 打包步骤 一.安装插件1.项目-->扩展-->管理扩展2.搜索-->下载3.下载完毕-->关闭VS4.Modify-->End Tasks&#xff08;跳过&#xff09;-->完成 二.配…

5.用python写网络爬虫,动态内容

目录 ​​​​​​​前言 5.1 动态网 页 示例 5.2 对动态网页进行逆向工程 5.2.1 边界情况 5.3 渲染动态网页 5.3.1 PyQt还是PySide 5.3.2 执行 JavaScript 5.3.3 使用WebKit与网站交互 1 . 等待结果 2. 渲染类 5.3.4 Selenium 5.4 本章小结 前言 根据联合国全球 网站可…