SpringBoot整合knif4j Api文档

前言

knife4j是为Java MVC框架集成Swagger生成Api文档的增强解决方案。

一、maven 依赖

        <!--接口文档-->
        <dependency>
            <groupId>com.github.xiaoymin</groupId>
            <artifactId>knife4j-spring-boot-starter</artifactId>
            <version>2.0.7</version>
        </dependency>

二、配置

package com.cyq.dascma.configuration;

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.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2WebMvc;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

/**
 * knife4j 配置类
 * dingwen
 * 2021/3/9 17:43
 **/
@Configuration
@EnableSwagger2WebMvc
@EnableKnife4j // 解决访问404问题。无需配置WebMvcConfigurer 
public class Knife4jConfiguration {
    @Bean(value = "defaultApi2")
    public Docket defaultApi2() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(new ApiInfoBuilder()
                        .title("接口文档- daily score management")
                        .description("# daily-score-management APIs")
                        .termsOfServiceUrl("http://192.168.0.117:9999/daily_score_management/student/list")
                        .contact(new Contact("xxxx", "www.dingwen.com", "xxx@qq.com"))
                        .version("v1.0")
                        .build())
                //忽略生成主键的参数类型
                      .ignoredParameterTypes(
	                      HttpSession.class, 		  	  
	                      HttpServletResponse.class,
	                      HttpServletRequest.class
                      )
                //分组名称
                .groupName("1.0版本")
                .select()
                //这里指定Controller扫描包路径
                .apis(RequestHandlerSelectors.basePackage("com.cyq.dascma.controller"))
                .paths(PathSelectors.any())
                .build();
    }
}

三、遇到问题

1.ignoredParameterTypes

忽略某些生成Key的参数类型

 .ignoredParameterTypes(
	                      HttpSession.class, 		  	  
	                      HttpServletResponse.class,
	                      HttpServletRequest.class
                      )

没有设置,当你的请求参数中有,HttpSession等时,会出现一下情况

在这里插入图片描述

设置后

在这里插入图片描述

2.访问 doc.html 404

编写WebMvcConfigurer 类添加静态资源映射

package com.cyq.dascma.configuration;

import com.cyq.dascma.interceptor.LoginInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.*;

/**
 * 全局拦截器
 * 登录
 * 跨域
 * dingwen
 * 2021/4/3 21:41
 **/
@Configuration
public class WebConfigurer implements WebMvcConfigurer {
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("doc.html").addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
    }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dingwen_blog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值