爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      SpringBoot入门二十九,整合Swagger3

      首页 知识中心 软件开发 文章详情页

      SpringBoot入门二十九,整合Swagger3

      2023-06-13 08:35:22 阅读次数:473

      Springboot,Swagger

      1. pom.xml添加引用

       引入knife4j是为了更好的支持Swagger3,不想引入也可以

      <!-- 3. 引入Swagger3依赖 -->
      <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-boot-starter</artifactId>
      <version>3.0.0</version>
      </dependency>

      <!-- 4. 引入knife4j依赖,用来增强Swagger3 -->
      <dependency>
      <groupId>com.github.xiaoymin</groupId>
      <artifactId>knife4j-spring-boot-starter</artifactId>
      <!--在引用时请在maven中央仓库搜索3.X最新版本号-->
      <version>3.0.3</version>
      </dependency>

      2. 添加配置信息

       application.properties

      # ----------------Swagger3配置---------------
      # Springboot2.6及以上版本整合Swagger3需要此配置,否则启动会报异常:
      # Failed to start bean 'documentationPluginsBootstrapper'; nested exception is java.lang.NullPointerException
      spring.mvc.pathmatch.matching-strategy=ant-path-matcher
      # 是否开启Swagger3文档
      springfox.documentation.enabled=true

      3. 添加配置类

      import org.springframework.context.annotation.Bean;
      import org.springframework.context.annotation.Configuration;

      import io.swagger.annotations.Api;
      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;

      @Configuration
      //@EnableOpenApi // 开启 Swagger3,可不写,访问地址:http://ip:port/projectName/swagger-ui/index.html
      public class SwaggerConfig {
      @Bean
      public Docket createRestApi() {
      return new Docket(DocumentationType.OAS_30)
      .apiInfo(apiInfo())
      .select() // 通过.select()方法,去配置扫描接口,RequestHandlerSelectors配置如何扫描接口
      .apis(RequestHandlerSelectors.withClassAnnotation(Api.class)) //仅扫描类上有@Api注解的
      // .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)) //仅扫描类上有@ApiOperation注解的
      // .apis(RequestHandlerSelectors.basePackage("com.qfx.controller")) //只扫描该包下面的接口
      .paths(PathSelectors.any()) //任何请求都扫描
      // .paths(PathSelectors.regex("/test/.*")) //匹配/test/开头的路径信息
      .build();
      }

      private ApiInfo apiInfo() {
      return new ApiInfoBuilder()
      .title("Swagger3接口文档") // 标题
      .description("适用于前后端分离统一的接口文档") // 描述
      .contact(new Contact("作者名称", "网址", "邮箱"))// 其他信息
      .version("1.0") // 版本
      .build();
      }
      }

       扩展:Swagger3.0常用注解

      @Api:用在请求的类上,描述Controller的作用
      tags=“说明该类的作用,可以在UI界面上看到的注解”
      value=“该参数没什么意义,在UI界面上也看到,所以不需要配置”

      @ApiOperation:用在请求的方法上,说明方法的用途、作用
      value=“说明方法的用途、作用”
      notes=“方法的备注说明”

      @ApiParam:单个参数描述

      @ApiImplicitParams:用在请求的方法上,表示一组参数说明
      @ApiImplicitParam:用在@ApiImplicitParams注解中,指定一个请求参数的各个方面
      name:参数名
      value:参数的汉字说明、解释
      required:参数是否必须传
      paramType:参数放在哪个地方
      · header --> 请求参数的获取:@RequestHeader
      · query --> 请求参数的获取:@RequestParam
      · path(用于restful接口)–> 请求参数的获取:@PathVariable
      · div(不常用)
      · form(不常用)
      dataType:参数类型,默认String,其它值dataType=“Integer”
      defaultValue:参数的默认值

      @ApiResponses:用在请求的方法上,表示一组响应
      @ApiResponse:用在@ApiResponses中,一般用于表达一个错误的响应信息
      code:数字,例如400
      message:信息,例如"请求参数没填好"
      response:抛出异常的类

      @ApiModel:用在返回对象类上,表示一个返回响应数据的信息(这种一般用在post创建的时候,使用@RequestBody这样的场景,
      请求参数无法使用@ApiImplicitParam注解进行描述的时候)

      @ApiIgnore:使用该注解忽略这个API

      @ApiModelProperty:用在属性上,描述响应类的属性

      4. 编写测试接口

      import org.springframework.web.bind.annotation.GetMapping;
      import org.springframework.web.bind.annotation.PathVariable;
      import org.springframework.web.bind.annotation.RequestMapping;
      import org.springframework.web.bind.annotation.RestController;

      import io.swagger.annotations.Api;
      import io.swagger.annotations.ApiImplicitParam;
      import io.swagger.annotations.ApiImplicitParams;
      import io.swagger.annotations.ApiOperation;

      @Api("测试类相关信息")
      @RestController
      @RequestMapping("test")
      public class TestCtrl {

      @ApiOperation("最简单的问候")
      @GetMapping("hello")
      public String hello () {
      return "你好,世界";
      }

      @ApiOperation(value = "稍微高级一点的问候", notes = "升级版")
      @ApiImplicitParam(name = "name", value = "用户名称")
      @GetMapping("hello/{name}")
      public String hello (@PathVariable String name) {
      return name + "你好";
      }

      @ApiOperation(value = "高级问候", notes = "最终版")
      @ApiImplicitParams({
      @ApiImplicitParam(name = "age", value = "年龄"),
      @ApiImplicitParam(name = "msg", value = "信息", required = false)
      })
      @GetMapping("helloExt/{name}/{age}")
      public String hello (@PathVariable String name, @PathVariable int age, String msg) {
      return name + "你好, 你今年" + age + "吗?,你带来的消息是:\"" + msg + "\"吗?";
      }
      }

      5. 测试

      5.1 默认Swagger文档首页

       默认Swagger文档首页:

      http://localhost/{项目名}/swagger-ui/index.html

      SpringBoot入门二十九,整合Swagger3

      5.2 默认knife4j文档首页

       默认Swagger文档首页:

      http://localhost/{项目名}/doc.html

      SpringBoot入门二十九,整合Swagger3

      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.51cto.com/abcd/5319178,作者:清风凌雪,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:谈谈SpringBoot中@Async注解使用的一些误区

      下一篇:超详细的SpringBoot+Vue+Jwt实现token的认证(重点部分讲解和完整的代码设计)

      相关文章

      2025-01-06 08:42:37

      Springboot入门三十六,logback配置

      Springboot入门三十六,logback配置

      2025-01-06 08:42:37
      logback , Springboot , 指定 , 日志 , 级别 , 配置文件 , 默认
      2024-12-19 08:40:27

      Springboot常用注解记录

      Springboot常用注解记录

      2024-12-19 08:40:27
      Springboot , 注解
      2024-12-04 07:18:18

      基于Springboot的新闻资讯发布系统设计与实现(源码+lw+部署文档+讲解等)

      基于Springboot的新闻资讯发布系统设计与实现(源码+lw+部署文档+讲解等)

      2024-12-04 07:18:18
      Springboot , 管理员
      2024-11-21 09:55:25

      Spring Boot与Swagger的集成

      Swagger是一种规范和完整的框架,用于生成、描述、调用和可视化RESTful风格的Web服务。它允许开发者设计、构建和文档化API,以便开发者和消费者能够更好地理解和使用API的功能。

      2024-11-21 09:55:25
      API , Swagger
      2024-11-13 09:03:59

      Spring Boot与OpenAPI的集成

      OpenAPI(以前称为Swagger)是一种用于设计、构建和文档化API的开放标准,它提供了强大的工具和库来简化API的开发和维护。

      2024-11-13 09:03:59
      API , Spring , Swagger
      2024-11-05 08:40:34

      Java 应用的 API 测试:使用 Postman 或 Swagger

      API测试是验证后端服务功能的关键步骤,确保API按预期工作,并满足性能和安全性要求。

      2024-11-05 08:40:34
      API , Swagger , 测试
      2024-11-05 08:40:02

      Java 应用的 API 文档自动化:使用 Swagger

      良好的API文档对于开发者理解和使用API至关重要。自动化API文档的生成可以节省时间,减少人为错误,并确保文档的实时更新。

      2024-11-05 08:40:02
      API , Swagger
      2024-09-24 06:31:08

      SpringBoot入门二十五,默认的404错误页面引入css和js文件

      SpringBoot入门二十五,默认的404错误页面引入css和js文件

      2024-09-24 06:31:08
      css , Springboot , 页面
      2024-09-24 06:29:56

      SpringBoot入门二十四,Application事件监听

      SpringBoot入门二十四,Application事件监听

      2024-09-24 06:29:56
      java , Springboot
      2024-09-24 06:29:30

      07_Springboot 整合 RabbitMQ【5个消息队列模式】

      07_Springboot 整合 RabbitMQ【5个消息队列模式】

      2024-09-24 06:29:30
      RabbitMQ , Springboot
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5229837

      查看更多

      最新文章

      Springboot入门三十六,logback配置

      2025-01-06 08:42:37

      Springboot常用注解记录

      2024-12-19 08:40:27

      Spring Boot与Swagger的集成

      2024-11-21 09:55:25

      Spring Boot与OpenAPI的集成

      2024-11-13 09:03:59

      Java 应用的 API 测试:使用 Postman 或 Swagger

      2024-11-05 08:40:34

      Java 应用的 API 文档自动化:使用 Swagger

      2024-11-05 08:40:02

      查看更多

      热门文章

      Eclipse安装springboot支持(sts)

      2023-06-12 08:59:59

      SpringBoot入门二十五,默认的404错误页面引入css和js文件

      2024-09-24 06:31:08

      Java:Springboot整合PageHelper实现分页

      2023-06-12 09:27:10

      Eclipse同一个Springboot项目启动多个实例

      2023-06-12 08:59:48

      Springboot设置虚拟文件目录

      2023-06-12 08:59:59

      Spring项目&Spring-boot-starter 组件&Spring Cloud 生态圈以及微服务简介

      2023-06-16 06:12:13

      查看更多

      热门标签

      java Java python 编程开发 代码 开发语言 算法 线程 Python html 数组 C++ 元素 javascript c++
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      Spring boot自定义parent POM

      SpringBoot入门二十二,使用Validation进行参数校验

      手把手入门Springboot2之Web

      Springboot入门三十六,logback配置

      Springboot2.x整合ElasticSearch7.x实战(二)

      Springboot05整合FastJson优化输出

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号