首页 > 其他分享 >springboot集成swagger

springboot集成swagger

时间:2023-12-05 09:46:25浏览次数:43  
标签:集成 swagger springboot springframework org import springfox annotation

1.pom引入

  <!--swagger-->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>

2.配置类

import com.google.common.base.Predicates;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
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;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

/**
 * @author :author
 * @date :Created in 2023/11/03 10:38:03
 * @description: SwaggerConfig
 */
@Configuration
@EnableSwagger2
public class SwaggerConfig {
    @Bean
    public Docket api() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .pathMapping("/")
                .select() // 选择那些路径和api会生成document
                .apis(RequestHandlerSelectors.any())// 对所有api进行监控
                //不显示错误的接口地址
                .paths(Predicates.not(PathSelectors.regex("/error.*")))//错误路径不监控
                .paths(PathSelectors.regex("/.*"))// 对根下所有路径进行监控
                .build();
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder().title("接口口文档档")
                .contact(new Contact("romeo", "", "[email protected]"))
                .description("这是SWAGGER_2生成的接口文档")
                .termsOfServiceUrl("NO terms of service")
                .license("The Apache License, Version 2.0")
                .licenseUrl("http://www.apache.org/licenses/LICENSE-2.0.html")
                .version("v1.0")
                .build();
    }
}

3.controller配置:

import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j; 
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.NotBlank;

/**
 * @author :author
 * @date :Created in 2023/10/25 08:39:33
 * @description: AdminController
 */
@Api(value = "api/admin/evidence/", tags = "管理端-存证信息")//swagger注解
@Slf4j
@RestController
@RequestMapping("api/admin/evidence/")
public class AdminEvidenceController extends AdminBaseController {

    @Resource
    EvidenceService evidenceService;

    @ApiOperation(value = "存证-分页", notes = "存证-分页")//swagger注解
    @AdminAuthorization
    @PostMapping("listPager")
    public JsonResult listPager(@RequestBody EviAdminQueryVO queryVO){
        return evidenceService.getAdminPager(queryVO);
    }
}

 4.访问http://127.0.0.1:9110/swagger-ui.html#/,9110是我自己项目的端口号,改成自己本项目的端口号即可

5.(可选)拦截器放行

如果配置了某种拦截器校验参数,需要对swagger的url放行,如:

package net.cnki.evidence.platform_evidence_author.config;

import net.cnki.evidence.platform_evidence_author.interceptor.CheckSignInterceptor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

/**
 * @author :author
 * @date :Created in 2023/10/07 15:46:54
 * @description: MyWebMvcConfig
 */
@Configuration
public class MyWebMvcConfig implements WebMvcConfigurer {


    @Autowired
    private YourInterceptor yourInterceptor;
    /**
     * 拦截器配置
     * @param registry
     */
    @Override
    public void addInterceptors(InterceptorRegistry registry) {

        registry.addInterceptor(yourInterceptor).addPathPatterns("/api/**").excludePathPatterns(
                "/**/*swagger*/**",//放行swagger
                "/api/xx/**"
        );

    }

    
}

 

标签:集成,swagger,springboot,springframework,org,import,springfox,annotation
From: https://www.cnblogs.com/zjfblog/p/17876525.html

相关文章

  • 【SpringBootWeb入门-2】请求响应-请求-Postman工具
    JavaWeb开发最常见的就是各类数据的请求以及响应,在讲解请求参数接收内容之前,我们先来介绍一款功能强大的接口测试工具:Postman。Postman介绍:一款功能强大的网页调试与发送网页HTTP请求的Chrome插件,作用:常用于进行接口测试。为什么要使用Postman?当前最为主流的开发模式是前后端分......
  • 掌握这些,轻松管理BusyBox:如何交叉编译和集成BusyBox
    在嵌入式系统中,由于设备的资源限制,需要开发人员寻找一种轻量、小型且使用广泛的工具集。而BusyBox就是这样一个在嵌入式系统中非常实用的工具集。本文将介绍如何在Ubuntu22.04平台上使用交叉编译器编译BusyBox,并将其集成到嵌入式系统中。什么是BusyBox工具集?BusyBox是......
  • 为什么要做ERP集成?ERP系统如何与其他业务应用程序集成
    什么是ERP集成?ERP集成是指将企业资源计划(Enterprise Resource Planning,ERP)系统与其他软件应用或业务流程进行无缝连接和整合的过程。ERP系统通常涵盖企业内部的各种功能模块,如财务、供应链管理、生产制造、销售和人力资源等。ETL集成能够将这些功能模块与其他业务系统(如客户关系......
  • SpringBoot 如何实现文件上传和下载
    一、文件上传——upload<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>文件上传SpringBoot提供了Multipart文件上传的支持。Multipart是HTTP协议中的一种方式,用于支持文件上传。下面我们将介绍如......
  • 自动化集成有哪些典型应用场景?
    为什么要做自动化场景集成?主要分为以下几点:提高效率/减少错误:减少人工操作、人为错误、人力成本,提高生产效率、生产质量和稳定性。提高可靠性:提高系统的可靠性和稳定性,减少系统故障和停机时间。节约资源:节约能源和物料资源,降低生产成本。适应变化:快速适应市场变化和客户需求......
  • 【Spring】SpringBoot3+ES(Elasticsearch)の環境構築
    参考URL:https://blog.csdn.net/cicada_smile/article/details/132308849https://www.cnblogs.com/hualess/p/11540477.htmlElasticsearchは、オープンソースの分散型検索エンジンであり、大量のデータをリアルタイムで検索、分析することができます。主にJavaで開発されており......
  • 美颜SDK是什么?集成第三方美颜SDK的步骤
    第三方美颜SDK提供了实时美颜效果。本文将深入探讨集成第三方美颜SDK的步骤,助您在应用中实现引人注目的美颜功能。 第一步:选择适合的第三方美颜SDK在开始之前,务必仔细选择一个适合您应用需求的第三方美颜SDK。不同的SDK可能具有不同的特性,包括美颜效果、性能消耗、定制能力等。在......
  • 基于Kubernetes构建持续集成
    GitLab+Jenkins+Kubernetes1要求:2安装Jenkins环境3安装Gitlab环境4连接Jenkins和Gitlab5配置Jenkins连接maven6配置CI/CD1要求:该公司决定采用GitLab+Jenkins来构建CICD环境,以缩短新功能开发上线周期,及时满足客户的需求,实现DevOps的部分流程,来减轻部署运维的负担,实现......
  • IDEA创建SpringBoot项目无法选择底版本JDK创建
    本地的IDEA版本为2021.3,当我们想要使用SpringInitializr快速创建一个SpringBoot项目时,会发现可以选择的JDK版本基本都是最新版本,而我们本地使用的JDK8,导致无法创建项目。解决方式:1、升级JDK版本因为Spring官网使用的Spring版本比较新,而新版的Spring不支持低版本的JDK了,所以我......
  • SpringBoot文件上传下载
    1、单文件上传这里的enctype的类型是mulitpart/form-data两种形式的提交,一种是以form表单的形式,一个是ajax的形式<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>上传文件</title><scriptsrc="https://cdn.bo......