文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

swagger3的配置和使用(一)

2023-10-10 11:42

关注

目录

Swagger3简介

swagger官网:传送门
swagger是一个Api框架,就是一个工具,就比如我们可以使用postman测试接口一样,swagger主要作用是生成RESTFUL接口的文档并且可以提供功能测试;
通过swagger可以获取项目的api结果,生成清晰的api文档,并可以进行一些自动化测试

Swagger的组成

  1. Swagger-tools:提供各种与Swagger进行集成和交互的工具。例如模式检验、Swagger 1.2文档转换成Swagger2.0文档等功能。
  2. Swagger-core:用于Java/Scala的的Swagger实现。与JAX-RS(Jersey、Resteasy、CXF…)、Servlets和Play框架进行集成。
  3. Swagger-js: 用于JavaScript的Swagger实现。
  4. Swagger-node-express: Swagger模块,用于node.js的Express web应用框架。
  5. Swagger-ui:一个无依赖的HTML、JS和CSS集合,可以为Swagger兼容API动态生成优雅文档。
  6. Swagger-codegen:一个模板驱动引擎,通过分析用户Swagger资源声明以各种语言生成客户端代码。

Swagger的Springboot配置

maven添加依赖

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

创建swagger的配置类

import com.github.xiaoymin.swaggerbootstrapui.annotations.EnableSwaggerBootstrapUI;import io.swagger.annotations.ApiOperation;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.context.annotation.Profile;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.*;import springfox.documentation.spi.DocumentationType;import springfox.documentation.spi.service.contexts.SecurityContext;import springfox.documentation.spring.web.plugins.Docket; import java.util.ArrayList;import java.util.HashSet;import java.util.List;import java.util.Set; @Configuration@Profile({"dev", "local"})@EnableOpenApi@EnableSwaggerBootstrapUIpublic class SwaggerConfig {             private boolean enable;         @Bean    public Docket createRestApi() {        return new Docket(DocumentationType.OAS_30).pathMapping("/")                // 用来创建该API的基本信息,展示在文档的页面中(自定义展示的信息)                                .apiInfo(apiInfo())                // 设置哪些接口暴露给Swagger展示                .select()                // 扫描所有有注解的api,用这种方式更灵活                .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))                // 扫描指定包中的swagger注解                // .apis(RequestHandlerSelectors.basePackage("com.doctorcloud.product.web.controller"))                // 扫描所有 .apis(RequestHandlerSelectors.any())                .paths(PathSelectors.regex("(?!/ApiError.*).*"))                .paths(PathSelectors.any())                .build()                // 支持的通讯协议集合                .protocols(newHashSet("https", "http"))                .securitySchemes(securitySchemes())                .securityContexts(securityContexts());     }         private Set<String> newHashSet(String type1, String type2) {        Set<String> set = new HashSet<>();        set.add(type1);        set.add(type2);        return set;    }         private List<SecurityScheme> securitySchemes() {        List<SecurityScheme> securitySchemes = new ArrayList<>();        securitySchemes.add(new ApiKey("token", "token", "header"));        return securitySchemes;    }         private List<SecurityContext> securityContexts() {        List<SecurityContext> securityContexts = new ArrayList<>();        securityContexts.add(SecurityContext.builder()                .securityReferences(defaultAuth())                .forPaths(PathSelectors.any()).build());        return securityContexts;    }          private List<SecurityReference> defaultAuth() {        AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything");        AuthorizationScope[] authorizationScopes = new AuthorizationScope[1];        authorizationScopes[0] = authorizationScope;        List<SecurityReference> securityReferences = new ArrayList<>();        securityReferences.add(new SecurityReference("Authorization", authorizationScopes));        return securityReferences;    }          private ApiInfo apiInfo() {        // 用ApiInfoBuilder进行定制        return new ApiInfoBuilder()                // 设置标题                .title("接口文档")                // 服务条款                .termsOfServiceUrl("NO terms of service")                // 描述                .description("这是SWAGGER_3生成的接口文档")                // 作者信息                .contact(new Contact("rongrong", "https://www.cnblogs.com/longronglang/", "rongrong@gmail.com"))                // 版本                .version("版本号:V1.0")                //协议                .license("The Apache License")                // 协议url                .licenseUrl("http://www.apache.org/licenses/LICENSE-2.0.html")                .build();    }}

说明:
swagger3 摒弃了@EnableSwagger2这个注解,改成了@EnableOpenApi
swagger3 使用DocumentationType.OAS_30,swagger2版本这里是DocumentationType.SWAGGER_2

访问路径

http:IP:端口号/swagger-ui/index.html
在这里插入图片描述

application.yml环境配置

添加如下内容,使得只在测试环境中才会有swagger,正式环境不显示

spring:  profiles:    active: dev

API分组

Swagger默认是一个default分组:
在这里插入图片描述
可以通过分组来实现对不同API的分类,分组可以使用Docket的groupName属性区分不同分组,并可以在Swagger中创建多个Docket的Bean实例来定义不同分组;

@Beanpublic Docket docketCategory() {    return new Docket(DocumentationType.OAS_30)            .apiInfo(apiInfo())            // 分组名称            .groupName("Category")            .enable(true)            .select()            .apis(RequestHandlerSelectors.basePackage("com.yang.takeout.backend.controller"))            // 过滤请求,只扫描请求以/category开头的接口            .paths(PathSelectors.ant("/category/**"))            .build();}@Beanpublic Docket docketEmployee() {    return new Docket(DocumentationType.OAS_30)            .apiInfo(apiInfo())            // 分组名称            .groupName("Employee")            .enable(true)            .select()            .apis(RequestHandlerSelectors.basePackage("com.yang.takeout.backend.controller"))            // 过滤请求,只扫描请求以/employee开头的接口            .paths(PathSelectors.ant("/employee/**"))            .build();}

这里我只配置了两个分组,可以多创建几个Docket实例实现多分组;

分组效果:
在这里插入图片描述

Swagger常用注解

注解说明

用于类上

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

用于方法上

@ApiOperation:用在请求的方法上,说明方法的用途、作用
value=“说明方法的用途、作用”
notes=“方法的备注说明”
在这里插入图片描述

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

@Api(tags="用户模块")@Controllerpublic class UserController {@ApiOperation(value="用户登录",notes="随边说点啥")@ApiImplicitParams({@ApiImplicitParam(name="mobile",value="手机号",required=true,paramType="form"),@ApiImplicitParam(name="password",value="密码",required=true,paramType="form"),@ApiImplicitParam(name="age",value="年龄",required=true,paramType="form",dataType="Integer")})@PostMapping("/login")public JsonResult login(@RequestParam String mobile, @RequestParam String password,@RequestParam Integer age){//...    return JsonResult.ok(map);}}

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

@Api(tags="用户模块")@Controllerpublic class UserController {@ApiOperation("获取用户信息")@ApiImplicitParams({@ApiImplicitParam(paramType="query", name="userId", dataType="String", required=true, value="用户Id")}) @ApiResponses({@ApiResponse(code = 200, message = "请求成功"),@ApiResponse(code = 400, message = "请求参数没填好"),@ApiResponse(code = 404, message = "请求路径没有或页面跳转路径不对")}) @ResponseBody@RequestMapping("/list")public JsonResult list(@RequestParam String userId) {...return JsonResult.ok().put("page", pageUtil);}}

用于对象类

@ApiModel:用于响应类上,表示一个返回响应数据的信息
(这种一般用在post创建的时候,使用@RequestBody这样的场景,
请求参数无法使用@ApiImplicitParam注解进行描述的时候)
@ApiModelProperty:用在属性上,描述响应类的属性
value–字段说明
name–重写属性名字
dataType–重写属性类型
required–是否必填
example–举例说明
hidden–隐藏

@ApiModel的功能:
1、当请求数据描述,即 @RequestBody 时, 用于封装请求(包括数据的各种校验)数据;
2、当响应值是对象时,即 @ResponseBody 时,用于返回值对象的描述。
当请求数据描述时, @RequestBody 时的使用

@ApiModel(description = "用户登录")public class UserLoginVO implements Serializable {private static final long serialVersionUID = 1L;@ApiModelProperty(value = "用户名",required=true)private String username;@ApiModelProperty(value = "密码",required=true)private String password;// getter/setter省略}
@Api(tags="用户模块")@Controllerpublic class UserController {@ApiOperation(value = "用户登录", notes = "")@PostMapping(value = "/login")public R login(@RequestBody UserLoginVO userLoginVO) {User user=userSerivce.login(userLoginVO);return R.okData(user);}}

借鉴:
【1】SpringBoot从0到实战8:简单使用Swagger生成接口开发文档
【2】 Swagger3 常用配置注解讲解 结合SpringBoot2
【3】Swagger笔记—Swagger3详细配置
【4】Swagger3的基本使用

来源地址:https://blog.csdn.net/ErnestW/article/details/129974134

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯