Swagger3 使用详解

Swagger3 使用详解

  • 一、简介
    • 1 引入依赖
    • 2 开启注解
    • 3 增加一个测试接口
    • 4 启动服务报错
    • 1.5 重新启动
    • 6 打开地址:http://localhost:8093/swagger-ui/index.html
  • 二、Swagger的注解
    • 1.注解@Api和@ApiOperation
    • 2.注解@ApiModel和@ApiModelProperty
    • 3.注解@ApiImplicitParams和@ApiImplicitParam
    • 4.注解@ApiResponses和ApiResponse
    • 5.注解@ApiIgnore
  • 三、Swagger的相关配置

一、简介

官方网站:https://swagger.io/
Swagger 是一个开源的 API 开发和文档框架,Swagger 旨在简化 RESTful API 的设计、开发、测试、文档化和消费过程。Swagger的出现节约了大量的后端人员对接接口的时间,通过Swagger可以快速定义接口文档,方便了前端后端的接口对接工作,废话不多说直接上用例。
这里使用的SpringBoot 是2.6.11 版本

1 引入依赖

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

2 开启注解

启动类增加注解

@EnableSwagger2
// 或者使用下面的注解,也是可以的
@EnableOpenApi

3 增加一个测试接口

增加一个接口,方便看到Swagger帮我们生成的接口文档中的接口信息,如下:

package com.cheng.ebbing.message.controller;

import com.cheng.ebbing.message.vo.UserVO;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @author pcc
 * @version 1.0.0
 * @description 测试接口
 */
@RestController
public class TestController {

    @RequestMapping(value ="/test")
    public UserVO test(){
        return new UserVO("zhangsan","1234",1);
    }
}

4 启动服务报错

报错:Failed to start bean ‘documentationPluginsBootstrapper’; nested exception is java.lang.NullPointerException
原因可以参考这篇文章 https://blog.csdn.net/weixin_45131680/article/details/131580270,总结一句话就是SpringBoot2.6以上的版本整合Swagger2:3.0.0会碰到这个问题,根本原因是路径匹配模式不适配。解决方案有两个,他们的目的是为了更改路径匹配规则以适配Swagger2 的3.0 的版本。

  • 解决方案一:
    // 启动类增加了开启swagger注解的基础上增加以下注解
    @EnableWebMvc
    
  • 解决方案二:
    配置文件增加以下配置:
    spring:
      mvc:
        pathmatch:
          matching-strategy: ant_path_matcher
    

1.5 重新启动

选择上面其中一个方案进行解决即可,然后重新启动就会正常了,如下:
在这里插入图片描述

6 打开地址:http://localhost:8093/swagger-ui/index.html

到这里swagger的入门集成就成功了,如果你没有设置项目的根路径,那么Swagger的地址就是这个了,如果设置了自行端口后增加根路径就行,打开后如下图:
在这里插入图片描述
界面里有四块信息是需要关注的。
左一:展示的信息支持自定义,可以用来标识文档的和服务的信息(第四部分进行详细介绍)
左二:接口展示,这里展示接口的详细信息,最常用的地方,可以看到上面定义的测试接口已经在这里了(第二部分详细介绍)
左三:这里展示我们再请求和响应中定义的实体信息,比如上面接口的UserVO就在这里(第二部分详细介绍)
右一:分组信息,一般用于多个微服务时对不同微服务进行分组,常用与和Gateway集成时对服务进行分组展示(第三部分详细介绍)

二、Swagger的注解

这里详细说下Swagger常用的注解,根据使用频率来进行先后说明。这里分为了五个部分来说,前四个部分都是分组来说的,每组注解基本都是一起使用的所以就放一起来说,也方便理解记忆。下面的前四组例子都将使用使用注解和不使用注解的方式来进行说明比对,以此来方便了解注解的具体的作用。

1.注解@Api和@ApiOperation

这是使用频率最高的一组注解了。@Api常用与接口类上,用以对当前的接口类做整体声明。@ApiOperation则用于接口方法上,用以描述具体的方法真。

  • @Api
    正使用时其实只需要为@Api声明tags标签即可(其他的基本用不到,如果需要再阅读下注解的源码即可),value的值在源码描述中说是当tags不使用时会将其作为资源的描述,但是笔者试了没啥用,而且大家都是使用tags,直接使用tags标签即可。假如存在下面两个方法,他们的信息基本都是相同的,一个使用了@Api注解,一个没有使用:

    // 使用了 @Api注解的类
    @Api(tags = "测试接口类1")
    @RestController
    public class TestController1 {
    
        @PostMapping("/test1Fun")
        public String test() {
            return "test1";
        }
    }
    
    
    // 未使用@Api注解的类
    @RestController
    public class TestController2 {
    
        @PostMapping("/test2Fun")
        public String test() {
            return "test2";
        }
    }
    

    下面一起看下他们在Swagger中的展示区别吧(注意重启生效):
    在这里插入图片描述
    可以看到使用后多了汉字的描述,这样对于文档使用者来说也就更为有好了,这也就是tags属性的作用了,其他属性基本不咋使用。

  • @ApiOperation
    这个注解则是使用在接口方法上的,用以描述一个具体的接口,它支持的所有属性都是和RequestMapping对应的,因为他本来就是用来描述接口的和RequestMapping对应则是很好理解的。不过最常用的还是他的value属性,用以简介当前的接口。其他用以描述接口的信息一般不设置也是可以看到的,我们一般使用value属性简单描述接口的作用。
    下面是一组使用@ApiOperation和不使用的代码:

    
    // 使用注解@ApiOperation
    @ApiOperation("测试接口1-方法1")
    @PostMapping("/test1Fun")
    public String test() {
        return "test1";
    }
    
    // 不使用注解@ApiOperation
    @PostMapping("/test2Fun")
    public String test() {
        return "test2";
    }
    

    下面一起看下使用注解和不使用注解在Swagger中的区别:
    在这里插入图片描述

2.注解@ApiModel和@ApiModelProperty

这组注解是使用在实体上的,一般前后端参数交互时都是使用Json数据进行交互,Json交互时后端使用实体和注解@RequestBody来接收前端传递的参数,而这组注解则是用来描述实体的。实体既可以作为接收参数当然也可以作为返回参数。下面一起来看下。

  • @ApiModel
    被用于修饰实体类,实体类可用于接口入参和返参,一般只使用value属性即可。假设有如下两个实体信息,一个加了ApiModel一个没有加:

    // 使用了注解@ApiModel的注解
    @Data
    @ApiModel("用户实体1")
    @AllArgsConstructor
    @NoArgsConstructor
    public class UserVO1 implements Serializable {
        private static final long serialVersionUID = 1L;
    
        private String username;
    
        private String password;
    
        Integer id;
    }
    
    
    // 不使用注解@ApiModel
    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    public class UserVO2 implements Serializable {
        private static final long serialVersionUID = 1L;
    
        private String username;
    
        private String password;
    
        Integer id;
    }
    

    先看下使用了注解时的样子(不使用则显示类名):
    在这里插入图片描述
    下面是不使用的样子:
    在这里插入图片描述
    此外在下面的位置也是可以看出区别的:
    在这里插入图片描述

  • @ApiModelProperty
    这个属性被用在实体的属性上,用来标识实体属性的含义,这个还是很有用的,因为不用他来标识的话有些字段是人无法知道具体代表的含义的。这个也是基本使用value即可,下面也是使用使用和不使用注解来比对下区别,这里就只贴使用注解的代码了

    @Data
    @ApiModel("用户实体1")
    @AllArgsConstructor
    @NoArgsConstructor
    public class UserVO1 implements Serializable {
        private static final long serialVersionUID = 1L;
    
        @ApiModelProperty("用户名")
        private String username;
    
        @ApiModelProperty("用户密码")
        private String password;
    
        @ApiModelProperty("用户ID")
        Integer id;
    }
    

    下面是在swagger文章中看到的区别:
    在这里插入图片描述

3.注解@ApiImplicitParams和@ApiImplicitParam

上面一组注解被用于标识使用实体接收和返回的数据对象,那么如果接受的数据不是json呢,则需要别的注解来处理了,这一组注解就可以实现这个功能。

  • 参数传递大致有以下几种
    • 1.使用body传递json,后端使用注解RequestBody来接收
    • 2.使用body传递form-data,后端使用注解RequestParam接收(文件除外)
    • 3.使用body传递x-www-form-urlencoded,后端使用注解RequestParam接收
    • 4.使用path传参(restful),后端使用注解PathVariable来接收
    • 5.使用query传参,即url传参,后端使用注解RequestParam接收
    • 6.使用Cookie传参,后端使用注解CookieValue接收

上面列举了集中数据的传递方式,可以看到除了Json进行传递,还有一些其他的数据传递,此时@ApiModel这组注解就无法满足我们的需要了,那就只能使用@ApiImplicitParams和@ApiImplicitParam。上面的这些数据传递(除了json)都会在接口方法有参数进行映射。所以使用这组注解就都可以进行声明。这组注解和上面还有一点区别就是必须同时使用。

这里使用query传参进行说明吧。假设有如下接口代码:

@ApiOperation("测试接口1-方法1")
@PostMapping("/test1Fun")
public UserVO1 test(@RequestParam("name")String name) {
    return new UserVO1("用户1","1234",10);
}

不使用注解时,swagger展示如下:
在这里插入图片描述
当添加了如下注解以后:

@ApiOperation("测试接口1-方法1")
@PostMapping("/test1Fun")
@ApiImplicitParams({
        @ApiImplicitParam(
                name = "name",
                value = "用户名",
                required = true,
                paramType = "query",
                dataType = "String",
                dataTypeClass = String.class
        )
})
public UserVO1 test(@RequestParam("name")String name) {
    return new UserVO1("用户1","1234",10);
}

swagger中展示如下:
在这里插入图片描述
注意:可以看到只是多了在注解ApiImplicitParam中描述的value其他都是相同的,所以说其实使用这组注解时只需要关注ApiImplicitParam他的value就行了。不过需要注意的是这里还是用了注解@RequestParam,swagger文档中的required和query是这个注解赋予的,如果没有这个注解swagger文档是不会有对应提示的。还有一点,若是使用ApiImplicitParam的dataType则一定要使用dataTypeClass不然会一直提示warn日志
在这里插入图片描述

4.注解@ApiResponses和ApiResponse

上一组注解时用来描述除了实体以外的入参的,这个注解从字面看就知道是跟返回信息有关的,先看下不加这个注解时的接口的返回在swagger中的展示:
在这里插入图片描述
然后我们为接口增加这组注解,如下:

    @ApiOperation("测试接口1-方法1")
    @PostMapping("/test1Fun")
    @ApiResponses({
            @ApiResponse(code = 200, message = "成功", response = UserVO1.class,reference = "UserVO1"),
            @ApiResponse(code = 400, message = "失败",response = UserVO1.class,reference = "UserVO1")
    })
    public UserVO1 test(@RequestParam("name")String name) {
        return new UserVO1("用户1","1234",10);
    }

下面是使用注解后的swagger文档展示:
在这里插入图片描述
可以看到真正有作用的是code和message,所以如果需要使用就使用这两个即可,不过一把不使用这组注解,因为后端服务一般不会抛出http的异常码,而是通过实体的错误码来标识响应信息。

5.注解@ApiIgnore

这个注解也比较简单,可以使用在类或者方法上都是可以的,用以将其排除,排除后swagger不会将其加入文档。
假如有如下代码:

    @ApiIgnore
    @ApiOperation("测试接口1-方法1")
    @PostMapping("/test1Fun")
    @ApiResponses({
            @ApiResponse(code = 200, message = "成功", response = UserVO1.class,reference = "UserVO1"),
            @ApiResponse(code = 400, message = "失败",response = UserVO1.class,reference = "UserVO1")
    })
    public UserVO1 test(@RequestParam("name")String name) {
        return new UserVO1("用户1","1234",10);
    }

因为加了该注解,我们再swagger中是看不到的:
在这里插入图片描述

三、Swagger的相关配置

其实不添加任何配置不影响使用,但知道配置方便我们更好地针对自己的特别需求进行定制化。所以配置还是需要进行了解和熟悉的。比如生产上是不推荐打开swagger的,因为有很大的安全隐患。下面一起说下,注意这些配置信息都需要放在配置文件,这里为了方便都直接写死了。

package com.cheng.ebbing.message;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.oas.annotations.EnableOpenApi;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;

/**
 * @author pcc
 * @version 1.0.0
 * @description swagger3配置类
 */
@EnableWebMvc // 适配springboot2.6和swagger3
@EnableOpenApi // 开启swagger3
@Configuration
public class config {

    @Bean
    public Docket  createRestApi(){
            return new Docket(DocumentationType.OAS_30)

                    .enable(true) // 开启swagger,生产建议关闭
                    .apiInfo(apiInfo()) // 配置文档的基础信息
                    .groupName("这是分组名")// 不设置默认都是default,单个服务可以不使用分组,如果想要多个分组再来个Docket设置组名即可
                    .select() // 开始配置路径相关信息
                    // 扫描固定包,其他包下的信息不回出现在swagger
                    .apis(RequestHandlerSelectors.basePackage("com.cheng.ebbing"))
                    // 扫描所有有注解的api,用这种方式更灵活,也可以扫描指定的接口,支持通配符
                    .paths(PathSelectors.any())
                    .build();
    }

    private ApiInfo apiInfo() {
        // 配置文档的基础信息,例如标题、描述等
        return new ApiInfoBuilder().title("这是title")
                .description("这是description")
                .license("这是license")
                .licenseUrl("这是licenseUrl")
                .termsOfServiceUrl("这是termsOfServiceUrl")
                .contact(new Contact("concat-name","concat-url","concat-email"))
                .version("版本1.0.0")
                .build();
    }
}

增加完配置信息以后,swagger文档展示如下:
在这里插入图片描述
这些配置信息,注意不要直接写死,而应该从配置文件获取,这里直接写死只是为了演示使用,swagger只是项目辅助的小框架就只说到这里了。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

如何在 Linux 上使用 dmesg 命令

文章目录 1. Overview2.ring buffer怎样工作&#xff1f;3.dmesg命令4.移除sudo需求5. 强制彩色输出6.使用人性化的时间戳7.使用dmesg的人性化可读时间戳8.观察实时event9.检索最后10条消息10.搜索特定术语11.使用Log Levels12.使用Facility Categories13.Combining Facility a…

【六袆-Golang】Golang:安装与配置Delve进行Go语言Debug调试

安装与配置Delve进行Go语言Debug调试 一、Delve简介二、win-安装Delve三、使用Delve调试Go程序[命令行的方式]四、使用Golang调试程序 Golang开发工具系列&#xff1a;安装与配置Delve进行Go语言Debug调试 摘要&#xff1a; 开发环境中安装和配置Delve&#xff0c;一个强大的G…

黑马程序员——接口测试——day03——Postman断言、关联、参数化

目录&#xff1a; Potman断言 Postman断言简介Postman常用断言 断言响应状态码断言包含某字符串断言JSON数据Postman断言工作原理Postman关联 简介实现步骤核心代码创建环境案例1案例2Postman参数化 简介数据文件简介编写数据文件 CSV文件JSON文件导入数据文件到postman读取数…

C语言-数据结构-顺序表

&#x1f308;个人主页: 会编辑的果子君 &#x1f4ab;个人格言:“成为自己未来的主人~” 目录 数据结构相关概念 顺序表 顺序表的概念和结构 线性表 顺序表分类 顺序表和数组的区别 顺序表分类 静态顺序表 动态顺序表 头插和尾插 尾插 数据结构相关概念 数据结构…

逆向案例二:关键字密文解密,自定义的加密解密。基于企名片科技的爬取。

import requests import execjsfor i in range(4):i i1url https://vipapi.qimingpian.cn/Activity/channelInformationByChannelNamedata {channel_name: 24新声,page: f{i},num: 20,unionid: W9wLD4rHIZrB3GLTUncmHgbZcEepR78xJa5Zit6XTMtata86DehdxDt/fDbcHeeJWqqIs6k…

Golang Redis:构建高效和可扩展的应用程序

利用Redis的闪电般的数据存储和Golang的无缝集成解锁协同效应 在当前的应用程序开发中&#xff0c;高效的数据存储和检索的必要性已经变得至关重要。Redis&#xff0c;作为一个闪电般快速的开源内存数据结构存储方案&#xff0c;为各种应用场景提供了可靠的解决方案。在这份完…

PHP请求示例获取淘宝商品详情数据API接口(按关键词搜索商品列表)

请求示例&#xff0c;API接口接入Anzexi58 item_get-获得淘宝商品详情 taobao.item_get 公共参数 名称类型必须描述keyString是调用key&#xff08;必须以GET方式拼接在URL中&#xff09;secretString是调用密钥WeChat18305163218api_nameString是API接口名称&#xff08;包…

nodejs 实现pdf与图片互转

PDF转图片 效果图 代码 const path require(path); const pdf require(pdf-poppler); const fs require(fs); // PDF文件路径 const pdfFilePath ./path/test.pdf; // 转换选项 const opts { format: png, // 输出图片格式&#xff0c;可以是 jpeg, png, ppm…

东芝工控机维修东芝电脑PC机维修FA3100A

TOSHIBA东芝工控机维修电脑控制器PC机FA3100A MODEL8000 UF8A11M 日本东芝TOSHIBA IA controller维修SYU7209A 001 FXMC12/FXMC11;BV86R-T2GKR-DR7YF-8CPPY-4T3QD; CPU处理单元是可编程逻辑控制器的控制部分。它按照可编程逻辑控制器系统程序赋予的功能接收并存储从编程器键入…

组合模式(Composite Pattern)C++

上一节&#xff1a;桥接模式&#xff08;Bridge Pattern&#xff09; C 文章目录 0.理论1.目的与应用场景2.实现方式 1.实践 0.理论 组合模式&#xff08;Composite Pattern&#xff09;是一种结构型设计模式&#xff0c;用于将对象组合成树形结构以表示“部分-整体”的层次结…

CodeSys中调用C语言写的动态库

文章目录 1.前言2.前期准备3.创建CodeSys库工程3.1.函数名必须包含_cext3.2.生成m4、c文件 4.搭建编译环境&#xff0c;编译出动态库*.so4.1.将ExtensionSDK文件夹拷贝到板子的一个目录中。4.2.创建工程目录&#xff0c;且将前面生成的m4、c文件拷贝到这个工程目录下4.3.执行ma…

亚信安慧AntDB数据库与流式处理的有机融合

流式处理的概念 2001年9月11日&#xff0c;美国世贸大楼被袭击&#xff0c;美国国防部第一次将“主动预警”纳入国防的宏观战略规划。而IBM作为当时全球最大的IT公司&#xff0c;承担了大量基础支撑软件研发的任务。其中2009年正式发布的IBM InfoSphere Streams&#xff0c;就是…

R语言——条形图数据可视化的多种方式

本文章将会介绍如何使用R语言中的ggplot2包使用条形图进行数据可视化。将会使用一个“生产企业原材料的订购与运输”的订单数据&#xff0c;该数据来自2021数学建模国赛C题。 某建筑和装饰板材的生产企业所用原材料主要是木质纤维和其他植物素纤维材料总体可分为 A B C 三种类…

密码学系列(四)——对称密码2

一、RC4 RC4&#xff08;Rivest Cipher 4&#xff09;是一种对称流密码算法&#xff0c;由Ron Rivest于1987年设计。它以其简单性和高速性而闻名&#xff0c;并广泛应用于网络通信和安全协议中。下面是对RC4的详细介绍&#xff1a; 密钥长度&#xff1a; RC4的密钥长度可变&am…

影像仪激光扫描功能,无缝连接2D/3D混合测量

在现代工业生产领域&#xff0c;影像仪用于质量控制和产品检测&#xff0c;是一个不可或缺的工具。它通过高精度的成像和图像处理技术&#xff0c;可以及时发现产品的缺陷和异常&#xff0c;以保证产品质量的稳定性和一致性。 影像仪的重要性及其面临的挑战 在工业生产方面&a…

分段与分页,LDT与GDT,页目录表与页表简单的认识

综合四篇文章看下分段与分页机制&#xff1a; 分段&#xff1a;LDT与GDT 分页&#xff1a;页目录表与页表 首先明确两个结论&#xff1a; 1.cr3里保存页目录表的基址的地址类型为物理地址&#xff0c;页目录表里的每一项也是页表的物理地址。 2.gdtr的地址和gdt里的描述符里的…

MySQL:开始深入其数据(一)DML

在上一章初识MySQL了解了如何定义数据库和数据表&#xff08;DDL&#xff09;&#xff0c;接下来我们开始开始深入其数据,对其数据进行访问&#xff08;DAL&#xff09;、查询DQL&#xff08;&#xff09;和操作(DML)等。 通过DML语句操作管理数据库数据 DML (数据操作语言) …

Vue3列表触底请求(上手体验hooks新特性)

今天我们来聊一聊业务开发中的触底请求&#xff0c;其实就是分页的一种&#xff0c;只不过传统的分页感觉很丑而已&#xff0c;正好我的小博客最近在做触底分页&#xff0c;借此机会来说一说具体怎么实现的&#xff0c;以及来带领大家使用一下Vue3中的新特性hooks函数。 案例和…

uniapp小程序uView自定义tabbar

两年没接触小程序&#xff0c;又重新拾请来 前言 工具&#xff1a;HBuilder X 3.99版本 微信开发者工具 1.06 语言&#xff1a;vue2 uView 一、创建项目 先使用HBuilder X工具创建一个空白uni-app项目 uviewTest 二、安装和配置 HBuilder X找到工具-》插件安装-》插件市场 u…

Flutter中高级JSON处理:使用json_serializable进行深入定制

Flutter中高级JSON处理 使用json_serializable库进行深入定制 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at: https://jclee95.blog.csdn.netEmail: 291148484163.com. Shenzhen ChinaAddress of this article:https://blog.csdn.net/qq_28550263/article/details/1363…