一、问题现象

SpringBoot版本:2.6.4

springfox swagger版本:

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

启动之后报错:

org.springframework.context.ApplicationContextException: Failed to start bean 'documentationPluginsBootstrapper'; nested exception is java.lang.NullPointerExceptionat org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:181) ~[spring-context-5.3.16.jar:5.3.16]at org.springframework.context.support.DefaultLifecycleProcessor.access$200(DefaultLifecycleProcessor.java:54) ~[spring-context-5.3.16.jar:5.3.16]at org.springframework.context.support.DefaultLifecycleProcessor$LifecycleGroup.start(DefaultLifecycleProcessor.java:356) ~[spring-context-5.3.16.jar:5.3.16]at java.lang.Iterable.forEach(Iterable.java:75) ~[na:1.8.0_202]at org.springframework.context.support.DefaultLifecycleProcessor.startBeans(DefaultLifecycleProcessor.java:155) ~[spring-context-5.3.16.jar:5.3.16]at org.springframework.context.support.DefaultLifecycleProcessor.onRefresh(DefaultLifecycleProcessor.java:123) ~[spring-context-5.3.16.jar:5.3.16]at org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:935) ~[spring-context-5.3.16.jar:5.3.16]at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:586) ~[spring-context-5.3.16.jar:5.3.16]at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) ~[spring-boot-2.6.4.jar:2.6.4]at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:740) [spring-boot-2.6.4.jar:2.6.4]at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:415) [spring-boot-2.6.4.jar:2.6.4]at org.springframework.boot.SpringApplication.run(SpringApplication.java:303) [spring-boot-2.6.4.jar:2.6.4]at org.springframework.boot.SpringApplication.run(SpringApplication.java:1312) [spring-boot-2.6.4.jar:2.6.4]at org.springframework.boot.SpringApplication.run(SpringApplication.java:1301) [spring-boot-2.6.4.jar:2.6.4]at com.mycan.cplatform.CplatformApplication.main(CplatformApplication.java:12) [classes/:na]at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_202]at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_202]at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_202]at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_202]at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) [spring-boot-devtools-2.6.4.jar:2.6.4]
Caused by: java.lang.NullPointerException: nullat springfox.documentation.spring.web.WebMvcPatternsRequestConditionWrapper.getPatterns(WebMvcPatternsRequestConditionWrapper.java:56) ~[springfox-spring-webmvc-3.0.0.jar:3.0.0]at springfox.documentation.RequestHandler.sortedPaths(RequestHandler.java:113) ~[springfox-core-3.0.0.jar:3.0.0]at springfox.documentation.spi.service.contexts.Orderings.lambda$byPatternsCondition$3(Orderings.java:89) ~[springfox-spi-3.0.0.jar:3.0.0]at java.util.Comparator.lambda$comparing$77a9974f$1(Comparator.java:469) ~[na:1.8.0_202]at java.util.TimSort.countRunAndMakeAscending(TimSort.java:355) ~[na:1.8.0_202]at java.util.TimSort.sort(TimSort.java:220) ~[na:1.8.0_202]at java.util.Arrays.sort(Arrays.java:1512) ~[na:1.8.0_202]at java.util.ArrayList.sort(ArrayList.java:1462) ~[na:1.8.0_202]at java.util.stream.SortedOps$RefSortingSink.end(SortedOps.java:387) ~[na:1.8.0_202]at java.util.stream.Sink$ChainedReference.end(Sink.java:258) ~[na:1.8.0_202]at java.util.stream.Sink$ChainedReference.end(Sink.java:258) ~[na:1.8.0_202]at java.util.stream.Sink$ChainedReference.end(Sink.java:258) ~[na:1.8.0_202]at java.util.stream.Sink$ChainedReference.end(Sink.java:258) ~[na:1.8.0_202]at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:482) ~[na:1.8.0_202]at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471) ~[na:1.8.0_202]at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708) ~[na:1.8.0_202]at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234) ~[na:1.8.0_202]at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499) ~[na:1.8.0_202]at springfox.documentation.spring.web.plugins.WebMvcRequestHandlerProvider.requestHandlers(WebMvcRequestHandlerProvider.java:81) ~[springfox-spring-webmvc-3.0.0.jar:3.0.0]at java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:193) ~[na:1.8.0_202]at java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1382) ~[na:1.8.0_202]at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481) ~[na:1.8.0_202]at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471) ~[na:1.8.0_202]at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708) ~[na:1.8.0_202]at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234) ~[na:1.8.0_202]at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499) ~[na:1.8.0_202]at springfox.documentation.spring.web.plugins.AbstractDocumentationPluginsBootstrapper.withDefaults(AbstractDocumentationPluginsBootstrapper.java:107) ~[springfox-spring-web-3.0.0.jar:3.0.0]at springfox.documentation.spring.web.plugins.AbstractDocumentationPluginsBootstrapper.buildContext(AbstractDocumentationPluginsBootstrapper.java:91) ~[springfox-spring-web-3.0.0.jar:3.0.0]at springfox.documentation.spring.web.plugins.AbstractDocumentationPluginsBootstrapper.bootstrapDocumentationPlugins(AbstractDocumentationPluginsBootstrapper.java:82) ~[springfox-spring-web-3.0.0.jar:3.0.0]at springfox.documentation.spring.web.plugins.DocumentationPluginsBootstrapper.start(DocumentationPluginsBootstrapper.java:100) ~[springfox-spring-web-3.0.0.jar:3.0.0]at org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:178) ~[spring-context-5.3.16.jar:5.3.16]... 19 common frames omitted

二、问题排查

查看异常堆栈的顶部,发现是此处报空指针异常:springfox.documentation.spring.web.WebMvcPatternsRequestConditionWrapper#getPatterns,

跟踪condition变量,发现是从springfox.documentation.spring.web.WebMvcRequestHandler#getPatternsCondition方法返回的WebMvcPatternsRequestConditionWrapper类的对象返回的。

找到类org.springframework.web.servlet.mvc.method.RequestMappingInfo,发现有两个很相近的方法,查看方法注释可以知道当其中一个起作用时,另外一个则返回null。所以,springfox的代码似乎不应该这样写,而是应该加上一个判断。

实际上,SpringBoot 2.6.0开始,请求路径与Spring MVC处理映射匹配的默认策略已从AntPathMatcher更改为PathPatternParser。但是可以通过设置spring.mvc.pathmatch.matching-strategy为ant-path-matcher来改变。

所以我们在application.properties文件中加上一行配置:

spring.mvc.pathmatch.matching-strategy=ant_path_matcher

启动项目,发现还是报错。继续看,发现还是有HandlerMethod的patternsCondition为空。

那么为了不报空指针异常,只能把这些HandlerMethod过滤掉,这些HandlerMethod是从RequestMappingInfoHandlerMapping获取的,那么通过过滤RequestMappingInfoHandlerMapping就可以达到目标,通过判断条件getPatternParser() == null进行判断,这样过滤之后,所有的HandlerMethod的getPatternsCondition()都不是为空的了。

于是,我们对WebMvcRequestHandlerProvider类型的Bean进行改造,添加代码:

@Bean
public BeanPostProcessor springfoxHandlerProviderBeanPostProcessor() {return new BeanPostProcessor() {@Overridepublic Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {if (bean instanceof WebMvcRequestHandlerProvider || bean instanceof WebFluxRequestHandlerProvider) {customizeSpringfoxHandlerMappings(getHandlerMappings(bean));}return bean;}private <T extends RequestMappingInfoHandlerMapping> void customizeSpringfoxHandlerMappings(List<T> mappings) {List<T> copy = mappings.stream().filter(mapping -> mapping.getPatternParser() == null).collect(Collectors.toList());mappings.clear();mappings.addAll(copy);}@SuppressWarnings("unchecked")private List<RequestMappingInfoHandlerMapping> getHandlerMappings(Object bean) {try {Field field = ReflectionUtils.findField(bean.getClass(), "handlerMappings");field.setAccessible(true);return (List<RequestMappingInfoHandlerMapping>) field.get(bean);} catch (IllegalArgumentException | IllegalAccessException e) {throw new IllegalStateException(e);}}};}

三、解决方案:

1. 添加配置文件:

spring.mvc.pathmatch.matching-strategy=ant_path_matcher

2. 添加代码配置:

@Bean
public BeanPostProcessor springfoxHandlerProviderBeanPostProcessor() {return new BeanPostProcessor() {@Overridepublic Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {if (bean instanceof WebMvcRequestHandlerProvider || bean instanceof WebFluxRequestHandlerProvider) {customizeSpringfoxHandlerMappings(getHandlerMappings(bean));}return bean;}private <T extends RequestMappingInfoHandlerMapping> void customizeSpringfoxHandlerMappings(List<T> mappings) {List<T> copy = mappings.stream().filter(mapping -> mapping.getPatternParser() == null).collect(Collectors.toList());mappings.clear();mappings.addAll(copy);}@SuppressWarnings("unchecked")private List<RequestMappingInfoHandlerMapping> getHandlerMappings(Object bean) {try {Field field = ReflectionUtils.findField(bean.getClass(), "handlerMappings");field.setAccessible(true);return (List<RequestMappingInfoHandlerMapping>) field.get(bean);} catch (IllegalArgumentException | IllegalAccessException e) {throw new IllegalStateException(e);}}};}

四、其他

Spring fox 已经大半年没有更新了,为了使用swagger折腾的费劲,其实现在也有其他的api文档方案,比如Spring doc和Apifox,可以考虑更换。

先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

SpringBoot 2.6. 整合springfox 3.0报错问题解决相关推荐

  1. SpringBoot 2.6.* 整合springfox 3.0报错问题解决

    一.问题现象 SpringBoot版本:2.6.4 springfox swagger版本: <dependency><groupId>io.springfox</gro ...

  2. xx.xib: error: Illegal Configuration: Safe Area Layout Guide before iOS 9.0报错问题解决

    之前是用xcode8.3.3创建的工程最近升级到Xcode9.0 遇见了这个问题 在Xcode 9.0以上 新建xib文件会报错 xx.xib: error: Illegal Configuratio ...

  3. Proteus软件下载安装(包含win10安装proteus8.0+报错问题解决)

    文章目录 1.软件下载 2.软件安装 3.问题解决 3-1.win10安装Proteus出现There is a problem with this Windows Installer package ...

  4. SpringBoot工程的pom报错问题解决

    eclipse使用maven搭建SpringBoot工程,pom.xml 第一行报错问题解决办法 最近想要用eclipse搭建Springboot项目,但是遇到一个问题,使用maven创建spring ...

  5. 整合rocketmq/stream-rocketmq启动报错channel.AbstractMessageChannel问题

    springboot整合rocketmq/stream-rocketmq启动报错 spring boot.springcloud.springcloud alibaba项目整合rocketmq时.一启 ...

  6. Linux/ubuntu 安装 redis 4.0报错解决:redis-server.service: Can't open PID file /var/run/redis/redis-server.

    此文首发于我的个人博客:Linux/ubuntu 安装 redis 4.0报错解决:redis-server.service: Can't open PID file /var/run/redis/r ...

  7. 关于Unsupported major.minor version 52.0报错问题解决方案

    关于Unsupported major.minor version 52.0报错问题解决方案 参考文章: (1)关于Unsupported major.minor version 52.0报错问题解决 ...

  8. 解决MySQL8.0报错:Unknown system variable 'validate_password_policy'

    解决MySQL8.0报错:Unknown system variable 'validate_password_policy'   一.问题描述 1.在安装MySQL8.0时,修改临时密码,因密码过于 ...

  9. Tensorflow2.0报错:ProfilerNotRunningError: Cannot stop profiling. No profiler is running.

    Tensorflow2.0报错:ProfilerNotRunningError: Cannot stop profiling. No profiler is running. 文章目录: 一.在使用T ...

最新文章

  1. 求字符串全排列 python实现
  2. flex gallery / 产品展示
  3. matlab散点图与colorbar,MATLAB如何为图像做colorbar
  4. delphi switch语句例子_「GCTT 出品」Go 系列教程——10. switch 语句
  5. mysql mariadb不能启动原因_MySQL(MariaDB)无法启动
  6. 在 GitHub 上收获 6519 颗 Star 的 Python 面试题资源,到底有多牛?
  7. python匿名函数_Python匿名函数
  8. poj 1961 Period kmp基础
  9. 用一个div模拟textarea的实现【前端每日一题-15】
  10. 截至20161212中国公司在美上市名单
  11. 第二章实践与认识及其发展规律
  12. 星际争霸2Beta版单机使用方法
  13. 知识图谱概论(二):概念具象化描述
  14. java打好基础的100道题库(勇敢牛牛不怕困难)
  15. 无意中发现软件下载网站 softonic
  16. Arch Linux 安装Google Earth
  17. 夫兵形象水,水之行避高趋下,兵之形避实击虚;水因地制流,兵因故制胜。故兵无常势水无常形。能因敌变化取胜者谓之神。
  18. Scilab的初步介绍
  19. cadence SPB17.4 - allegro - Allegro2Altium.bat 初探
  20. 敏感词汇过滤(不区分大小写)

热门文章

  1. Linux开源存储全栈详解
  2. 鼠标滚轮控制图片的放大和缩小
  3. 荧光分光光度计的原理及应用
  4. Matplotlib雷达图、三维饼状图
  5. miniconda安装和配置
  6. 【ubuntu】由于没有公钥,无法验证下列签名: NO_PUBKEY 15CF4D18AF4F7421
  7. 问题-不在以下 request 合法域名列表中,请参考文档
  8. 基于QT的摄像头简单调用
  9. 蓝桥云课linux入门3:用户及文件权限管理
  10. 终止线程 4 种方式