Swagger 3 的基本使用_/v3/api-docs/swagger-config-程序员宅基地

技术标签: 学习  swagger2  

本内容根据江南一点雨松哥的 SpringBoot 付费视频所做的学习笔记,想具体详细了解内容的,请关注微信公众号:江南一点雨。

14.1 Swagger3 准备工作

swagger2和swagger3的区别

在 SpringBoot 中使用 Swagger3 需要导入以下依赖:

<dependency>
  <groupId>io.springfox</groupId>
  <artifactId>springfox-boot-starter</artifactId>
  <version>3.0.0</version>
</dependency>

我们导入依赖后,此时创建一个 HelloController 接口,Swagger3 会自动帮助我们生成接口文档,不需要在进行任何配置。

  • 文档接口地址:http://localhost:8080/v3/api-docs
  • 文档页面地址:http://localhost:8080/swagger-ui/index.html

我们访问文档页面地址可以看到项目的接口文档。
image-20210731164709832
我们可以通过配置类修改接口文档UI的内容:

@Configuration
public class swaggerConfig {
    

    @Bean
    Docket docket(){
    
        // 设置 swagger的版本
        return new Docket(DocumentationType.OAS_30)
                // 选择生成接口文档
                .select()
                // 包所在的路径
                .apis(RequestHandlerSelectors.basePackage("org.crc.swagger3.controller"))
                // 当前包下所有接口都生成
                .paths(PathSelectors.any())
                .build()
                // 接口文档初始化,也就是设置接口文档的详细信息,
                .apiInfo(
                    new ApiInfoBuilder()
                        .description("xxx 项目接口文档")
                         // 联系人
                        .contact(new Contact("crc","https://blog.csdn.net/cenrc?spm=1001.2101.3001.5343","[email protected]"))
                        .version("v1.0")
                        .title("API 测试文档")
                        .license("Apache 2.0")
                        .licenseUrl("http://www.apache.org/licenses/LICENSE-2.0")
                        .build()
                );
    }
}

修改之后接口文档的页面:
image-20210731165909516

14.2 Swagger 3 的基本使用

注意,这里出现的注解有部分是 swagger 2中的注解,但是在swagger 3 中同样适用。

  • @ApiOperation注解。

在接口中添加 @ApiOperation ,用于表述接口的作用

@ApiOperation(value = "查询用户",notes = "根据 id 查询用户")
@GetMapping("/user/{id}")
public String getUserById(@PathVariable Integer id){
    
    return "user: " + id;
}

默认情况显示:
image-20210731170955513
添加注解之后显示:
image-20210731171359578

@ApiOperation注解是 swagger 2 中提供的注解,swagger 3同样提供了一个类似的注解 @Operation,可以实现与 @ApiOperation注解一样的效果。

使用方式:

// swagger 2
@ApiOperation(value = "查询用户",notes = "根据 id 查询用户")
// swagger 3
@Operation(summary = "查询用户",description = "根据 id 查询用户")
  • @ApiImplicitParam 注解。

基本使用方式:

@ApiImplicitParam(paramType = "path",name = "id",value = "用户 id",required = true)
@GetMapping("/user/{id}")
public String getUserById(@PathVariable Integer id){
    
    return "user: " + id;
}

@ApiImplicitParam 注解是用于描述接口的参数信息。

其中 paramType 属性表示参数的类型,参数的类型有以下几种:

path : 表示参数放在地址栏中

query :表示参数是以 key / value 的形式传递

body :表示参数是放在请求体中

name 属性表示参数的名字,value 属性表示参数的表述信息,required 属性表示参数是否是必须的(注意,这里相对的是swagger 接口文档而言,与项目实际运行无关)。

如果存在多个参数需要进行描述信息,那么可以使用@ApiImplicitParams注解。

@ApiImplicitParams({
    
        @ApiImplicitParam(paramType = "path",name = "id",value = "用户 id",required = true),
        @ApiImplicitParam(paramType = "body",name = "id",value = "用户 id",required = true)
})

默认情况显示:
image-20210731172853361
添加注解之后显示:
image-20210731172942565

  • @ApiResponses 注解。

通过使用 @ApiResponses 注解,我们可以设置接口返回状态码的提示信息。

@ApiResponses({
    
        @ApiResponse(responseCode = "200",description = "请求成功"),
        @ApiResponse(responseCode = "500",description = "请求失败")
})
@GetMapping("/user/{id}")
public String getUserById(@PathVariable Integer id){
    
    return "user: " + id;
}

默认情况显示:
image-20210731173528712
添加注解之后显示:
image-20210731173609108
与实体类相关的注解。

  • @ApiModel 注解 与 @ApiModelProperty 的结合使用。

我们通过以上两个注解用户描述实体类的相关信息。

@ApiModel(value = "用户实体类",description = "这个类定义了用户的所有属性")
public class User {
    
    @ApiModelProperty(value = "用户 id")
    private int id;
    @ApiModelProperty("用户名")
    private String name;
    @ApiModelProperty("用户地址")
    private String address;
}

@PostMapping("/user")
public User user(@RequestBody User user){
    
    return user;
}

默认情况显示:

image-20210731174830273

添加注解之后显示:
image-20210731174941793

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/cenrc/article/details/119279683

智能推荐

c# 调用c++ lib静态库_c#调用lib-程序员宅基地

文章浏览阅读2w次,点赞7次,收藏51次。四个步骤1.创建C++ Win32项目动态库dll 2.在Win32项目动态库中添加 外部依赖项 lib头文件和lib库3.导出C接口4.c#调用c++动态库开始你的表演...①创建一个空白的解决方案,在解决方案中添加 Visual C++ , Win32 项目空白解决方案的创建:添加Visual C++ , Win32 项目这......_c#调用lib

deepin/ubuntu安装苹方字体-程序员宅基地

文章浏览阅读4.6k次。苹方字体是苹果系统上的黑体,挺好看的。注重颜值的网站都会使用,例如知乎:font-family: -apple-system, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Microsoft YaHei, Source Han Sans SC, Noto Sans CJK SC, W..._ubuntu pingfang

html表单常见操作汇总_html表单的处理程序有那些-程序员宅基地

文章浏览阅读159次。表单表单概述表单标签表单域按钮控件demo表单标签表单标签基本语法结构<form action="处理数据程序的url地址“ method=”get|post“ name="表单名称”></form><!--action,当提交表单时,向何处发送表单中的数据,地址可以是相对地址也可以是绝对地址--><!--method将表单中的数据传送给服务器处理,get方式直接显示在url地址中,数据可以被缓存,且长度有限制;而post方式数据隐藏传输,_html表单的处理程序有那些

PHP设置谷歌验证器(Google Authenticator)实现操作二步验证_php otp 验证器-程序员宅基地

文章浏览阅读1.2k次。使用说明:开启Google的登陆二步验证(即Google Authenticator服务)后用户登陆时需要输入额外由手机客户端生成的一次性密码。实现Google Authenticator功能需要服务器端和客户端的支持。服务器端负责密钥的生成、验证一次性密码是否正确。客户端记录密钥后生成一次性密码。下载谷歌验证类库文件放到项目合适位置(我这边放在项目Vender下面)https://github.com/PHPGangsta/GoogleAuthenticatorPHP代码示例://引入谷_php otp 验证器

【Python】matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距-程序员宅基地

文章浏览阅读4.3k次,点赞5次,收藏11次。matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距

docker — 容器存储_docker 保存容器-程序员宅基地

文章浏览阅读2.2k次。①Storage driver 处理各镜像层及容器层的处理细节,实现了多层数据的堆叠,为用户 提供了多层数据合并后的统一视图②所有 Storage driver 都使用可堆叠图像层和写时复制(CoW)策略③docker info 命令可查看当系统上的 storage driver主要用于测试目的,不建议用于生成环境。_docker 保存容器

随便推点

网络拓扑结构_网络拓扑csdn-程序员宅基地

文章浏览阅读834次,点赞27次,收藏13次。网络拓扑结构是指计算机网络中各组件(如计算机、服务器、打印机、路由器、交换机等设备)及其连接线路在物理布局或逻辑构型上的排列形式。这种布局不仅描述了设备间的实际物理连接方式,也决定了数据在网络中流动的路径和方式。不同的网络拓扑结构影响着网络的性能、可靠性、可扩展性及管理维护的难易程度。_网络拓扑csdn

JS重写Date函数,兼容IOS系统_date.prototype 将所有 ios-程序员宅基地

文章浏览阅读1.8k次,点赞5次,收藏8次。IOS系统Date的坑要创建一个指定时间的new Date对象时,通常的做法是:new Date("2020-09-21 11:11:00")这行代码在 PC 端和安卓端都是正常的,而在 iOS 端则会提示 Invalid Date 无效日期。在IOS年月日中间的横岗许换成斜杠,也就是new Date("2020/09/21 11:11:00")通常为了兼容IOS的这个坑,需要做一些额外的特殊处理,笔者在开发的时候经常会忘了兼容IOS系统。所以就想试着重写Date函数,一劳永逸,避免每次ne_date.prototype 将所有 ios

如何将EXCEL表导入plsql数据库中-程序员宅基地

文章浏览阅读5.3k次。方法一:用PLSQL Developer工具。 1 在PLSQL Developer的sql window里输入select * from test for update; 2 按F8执行 3 打开锁, 再按一下加号. 鼠标点到第一列的列头,使全列成选中状态,然后粘贴,最后commit提交即可。(前提..._excel导入pl/sql

Git常用命令速查手册-程序员宅基地

文章浏览阅读83次。Git常用命令速查手册1、初始化仓库git init2、将文件添加到仓库git add 文件名 # 将工作区的某个文件添加到暂存区 git add -u # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件git add -A # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件...

分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120-程序员宅基地

文章浏览阅读202次。分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120

【C++缺省函数】 空类默认产生的6个类成员函数_空类默认产生哪些类成员函数-程序员宅基地

文章浏览阅读1.8k次。版权声明:转载请注明出处 http://blog.csdn.net/irean_lau。目录(?)[+]1、缺省构造函数。2、缺省拷贝构造函数。3、 缺省析构函数。4、缺省赋值运算符。5、缺省取址运算符。6、 缺省取址运算符 const。[cpp] view plain copy_空类默认产生哪些类成员函数

推荐文章

热门文章

相关标签