当前位置: 首页 > news >正文

spring boot 3.x 整合Swagger3

环境介绍

  • jdk版本: 17
  • spring boot 版本:3.2.0
  • Swagger3版本:2.2.0

整合Swagger

添加依赖

<dependency><groupId>org.springdoc</groupId><artifactId>springdoc-openapi-starter-webmvc-ui</artifactId><version>2.2.0</version></dependency>

添加配置类 

package com.tech.cloud.config;import io.swagger.v3.oas.models.ExternalDocumentation;
import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Info;
import org.springdoc.core.models.GroupedOpenApi;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class Swagger3Config {// 按模块定义 当前支付模块@Beanpublic GroupedOpenApi PayApi() {return GroupedOpenApi.builder().group("支付微服务模块").pathsToMatch("/pay/**").build();}// 举例其他模块@Beanpublic GroupedOpenApi OtherApi() {return GroupedOpenApi.builder().group("其他微服务模块").pathsToMatch("/other/**", "others").build();}// 生成文档@Beanpublic OpenAPI docsOpenApi() {return new OpenAPI().info(new Info().title("cloud_tech").description("通用架构设计").version("v1.0")).externalDocs(new ExternalDocumentation().description("整合目前微服务最新组件,基于jdk17、spring boot3.2.0").url("www.baidu.com"));}}

在项目中使用

接口中使用

  • 类上 @Tag(name = "支付服务模块", description = "支付CRUD")
  • 方法上  @Operation(summary = "新增", description = "新增支付流水方法")

@RestController
@Slf4j
@Tag(name = "支付服务模块", description = "支付CRUD")
public class PaymentController {@Resourceprivate PaymentService payService;@PostMapping(value = "/pay/add")@Operation(summary = "新增", description = "新增支付流水方法")public ResultData<String> addPay(@RequestBody PaymentPO pay) {System.out.println(pay.toString());int i = payService.add(pay);return ResultData.success("成功插入记录,返回值: " + i);}@DeleteMapping(value = "/pay/del/{id}")@Operation(summary = "删除", description = "删除支付流水方法")public ResultData<Integer> deletePay(@PathVariable("id") Integer id) {int i = payService.delete(id);return ResultData.success(i);}@PutMapping(value = "/pay/update")@Operation(summary = "修改", description = "修改支付流水方法")public ResultData<String> updatePay(@RequestBody PayDTO payDTO) {PaymentPO pay = new PaymentPO();BeanUtils.copyProperties(payDTO, pay);int i = payService.update(pay);return ResultData.success("成功修改记录,返回值: " + i);}@GetMapping(value = "/pay/get/{id}")@Operation(summary = "按照ID查流水", description = "查询支付流水方法")public ResultData<PaymentPO> getPayInfo(@PathVariable("id") Integer id) {return ResultData.success( payService.getById(id));}@GetMapping(value = "/get/all")@Operation(summary = "获取所有", description = "获取所有")public ResultData getAll() {List<PaymentPO> all = payService.getAll();return ResultData.success(all);}}

实体类中使用

  • 类上和字段上@Schema(title = "主键")

@Data
@Table(name = "t_pay")
@Schema(title = "支付交易表实体类")
public class PaymentPO {@Id@GeneratedValue(generator = "JDBC")@Schema(title = "主键")private Integer id;/*** 支付流水号*/@Column(name = "pay_no")@Schema(title = "支付流水号")private String payNo;/*** 订单流水号*/@Column(name = "order_no")@Schema(title = "订单流水号")private String orderNo;/*** 用户账号ID*/@Column(name = "user_id")@Schema(title = "用户账号ID")private Integer userId;/*** 交易金额*/@Schema(title = "交易金额")private BigDecimal amount;/*** 删除标志,默认0不删除,1删除*/private Byte deleted;/*** 创建时间*/@Column(name = "create_time")@Schema(title = "创建时间")@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")private Date createTime;/*** 更新时间*/@Column(name = "update_time")@Schema(title = "更新时间")@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")private Date updateTime;
}

访问Swagger

主机名:端口/swagger-ui/index.html,我这里访问http://localhost:9100/swagger-ui/index.html

 按模块展示

 

查看标注的实体类 


http://www.mrgr.cn/news/61719.html

相关文章:

  • 【Linux】MySQLMGR主从复制
  • 聊一聊Elasticsearch的一些基本信息
  • 安装双系统后ubuntu无法联网(没有wifi标识)网卡驱动为RTL8852BE
  • 利用 Direct3D 绘制几何体—9.流水线状态对象
  • kaggle 数据集下载
  • 关于AI绘画 | Stable Diffusion 技术专栏推荐文章
  • 【传知代码】知识图谱推理(论文复现)
  • 利用大语言模型实现模拟版图自动化
  • 认知战认知作战:顺治帝迁都北京的认知作战分析与策略
  • 预告帖|在MATLAB/Simulink中调用C语言的几种方法
  • 查询windows或者linux上 支持的所有字体
  • Kubeadm搭建k8s
  • 直播带货视频素材网站推荐
  • 跟着小土堆学习pytorch(五)——dataloader
  • Java爬虫的京东“寻宝记”:揭秘商品类目信息
  • vue打包的dist文件,再使用eletron打包为exe
  • GitHub Copilot 转型采用多模型策略,支持 Claude 3.5 和 Gemini
  • Cesium中遇到 materialProperty.getType is not a function
  • 2024 FinTechathon 校园行:助力高校学生探索金融科技创新
  • PHP爬虫的奇幻之旅:如何用代码“偷窥”京东商品的SKU信息
  • 使用Python实现一个简单的HTTP服务器:返回当前时间
  • 【机器学习】音乐与AI的交响:机器学习在音乐产业中的应用
  • Ubuntu 20.04 安装 OpenCV 和 OpenCV_contrib 教程
  • CodeS:构建用于文本到 SQL 的开源语言模型
  • 戴尔 Inspiron 14 5418 (11代)安装win10 ltsc lot 企业版
  • 这些人真TM野路子!用AI赚了百万