news 2026/5/1 5:03:31

【后端】【Java】Swagger 与 Spring Boot 2.6+ 版本不兼容的问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【后端】【Java】Swagger 与 Spring Boot 2.6+ 版本不兼容的问题

Spring Boot 2.6+ 修改了路径匹配策略,导致 Springfox Swagger 3.0.0 出现空指针异常,启动后报错如下所示:

2025-12-16 00:00:56 [main] INFO o.a.catalina.core.StandardService - Stopping service [Tomcat] 2025-12-16 00:00:56 [main] INFO o.s.b.a.l.ConditionEvaluationReportLoggingListener - Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled. 2025-12-16 00:00:56 [main] ERROR o.s.boot.SpringApplication - Application run failed org.springframework.context.ApplicationContextException: Failed to start bean 'documentationPluginsBootstrapper'; nested exception is java.lang.NullPointerException: Cannot invoke "org.springframework.web.servlet.mvc.condition.PatternsRequestCondition.getPatterns()" because "this.condition" is null at org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:181) at org.springframework.context.support.DefaultLifecycleProcessor.access$200(DefaultLifecycleProcessor.java:54) at org.springframework.context.support.DefaultLifecycleProcessor$LifecycleGroup.start(DefaultLifecycleProcessor.java:356) at java.base/java.lang.Iterable.forEach(Iterable.java:75) at org.springframework.context.support.DefaultLifecycleProcessor.startBeans(DefaultLifecycleProcessor.java:155) at org.springframework.context.support.DefaultLifecycleProcessor.onRefresh(DefaultLifecycleProcessor.java:123) at org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:937) at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:586) at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:745) at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:423) at org.springframework.boot.SpringApplication.run(SpringApplication.java:307) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1317) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1306) at com.example.chapter05.Chapter05Application.main(Chapter05Application.java:13) Caused by: java.lang.NullPointerException: Cannot invoke "org.springframework.web.servlet.mvc.condition.PatternsRequestCondition.getPatterns()" because "this.condition" is null at springfox.documentation.spring.web.WebMvcPatternsRequestConditionWrapper.getPatterns(WebMvcPatternsRequestConditionWrapper.java:56) at springfox.documentation.RequestHandler.sortedPaths(RequestHandler.java:113) at springfox.documentation.spi.service.contexts.Orderings.lambda$byPatternsCondition$3(Orderings.java:89) at java.base/java.util.Comparator.lambda$comparing$77a9974f$1(Comparator.java:473) at java.base/java.util.TimSort.countRunAndMakeAscending(TimSort.java:355) at java.base/java.util.TimSort.sort(TimSort.java:220) at java.base/java.util.Arrays.sort(Arrays.java:1307) at java.base/java.util.ArrayList.sort(ArrayList.java:1721) at java.base/java.util.stream.SortedOps$RefSortingSink.end(SortedOps.java:392) at java.base/java.util.stream.Sink$ChainedReference.end(Sink.java:258) at java.base/java.util.stream.Sink$ChainedReference.end(Sink.java:258) at java.base/java.util.stream.Sink$ChainedReference.end(Sink.java:258) at java.base/java.util.stream.Sink$ChainedReference.end(Sink.java:258) at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:510) at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:499) at java.base/java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:921) at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234) at java.base/java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:682) at springfox.documentation.spring.web.plugins.WebMvcRequestHandlerProvider.requestHandlers(WebMvcRequestHandlerProvider.java:81) at java.base/java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:197) at java.base/java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1625) at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:509) at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:499) at java.base/java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:921) at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234) at java.base/java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:682) at springfox.documentation.spring.web.plugins.AbstractDocumentationPluginsBootstrapper.withDefaults(AbstractDocumentationPluginsBootstrapper.java:107) at springfox.documentation.spring.web.plugins.AbstractDocumentationPluginsBootstrapper.buildContext(AbstractDocumentationPluginsBootstrapper.java:91) at springfox.documentation.spring.web.plugins.AbstractDocumentationPluginsBootstrapper.bootstrapDocumentationPlugins(AbstractDocumentationPluginsBootstrapper.java:82) at springfox.documentation.spring.web.plugins.DocumentationPluginsBootstrapper.start(DocumentationPluginsBootstrapper.java:100) at org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:178) ... 14 common frames omitted

修复方案:

在 application.yml 中添加了以下配置:

spring: mvc: pathmatch: matching-strategy: ant_path_matcher

📝 问题说明

原因:

  • Spring Boot 2.6+ 默认使用 PathPatternParser作为路径匹配策略
  • Springfox Swagger 3.0.0 仍然使用旧的 AntPathMatcher
  • 两者不兼容导致空指针异常

解决办法:
将 Spring MVC 的路径匹配策略改回 ant_path_matcher,使其与 Swagger 兼容。

🚀 现在可以重新启动应用

重启 Chapter05Application 后:
- 应用将正常启动
- Swagger UI 可访问:http://localhost:8080/swagger-ui/
- 所有 RESTful 接口正常工作

如果您不需要 Swagger 文档功能,也可以选择删除 Swagger 相关依赖和配置类。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 3:43:39

基于神经图灵机的高级算法自动优化在软件工程中的应用

基于神经图灵机的高级算法自动优化在软件工程中的应用关键词:神经图灵机、算法自动优化、软件工程、深度学习、数据处理摘要:本文聚焦于神经图灵机在软件工程领域算法自动优化方面的应用。首先介绍了研究背景、目的和适用读者群体,明确了文档…

作者头像 李华
网站建设 2026/5/1 3:46:22

零基础入门Stable Diffusion 3.5 FP8:手把手教你完成Python安装配置

零基础入门Stable Diffusion 3.5 FP8:手把手教你完成Python安装配置 在如今这个内容爆炸的时代,谁能更快地产出高质量图像,谁就掌握了视觉表达的主动权。从电商海报到游戏原画,从社交媒体配图到AI艺术创作,文本生成图像…

作者头像 李华
网站建设 2026/5/1 3:46:34

diskinfo下载官网之外的选择:监控Qwen3-VL-30B运行状态的硬件工具

超越diskinfo:构建Qwen3-VL-30B大模型的硬件级可观测体系 在AI推理系统日益复杂的今天,一个看似简单的“响应变慢”问题,背后可能隐藏着SSD重映射扇区、GPU因过热降频,甚至是机房供电波动等物理层异常。尤其是在部署像Qwen3-VL-30…

作者头像 李华
网站建设 2026/5/1 3:43:42

CUDA安装与FP8支持:让Stable Diffusion 3.5在RTX4090上飞起来

CUDA安装与FP8支持:让Stable Diffusion 3.5在RTX4090上飞起来在生成式AI席卷内容创作领域的今天,一个现实问题摆在每一位开发者和创作者面前:如何在有限的硬件条件下,高效运行像 Stable Diffusion 3.5 这样的庞然大物?…

作者头像 李华
网站建设 2026/5/1 3:45:15

如何部署Wan2.2-T2V-A14B镜像并调用token进行推理?

如何部署 Wan2.2-T2V-A14B 镜像并调用 token 进行推理? 在内容创作节奏日益加快的今天,视频生成技术正经历一场由大模型驱动的范式变革。传统影视制作依赖专业团队与高昂成本,而如今,“一句话生成一段高清短视频”已不再是科幻场景…

作者头像 李华
网站建设 2026/4/23 13:56:05

k230 Pyhton三角形识别

本文介绍了一个基于K230 CanMV开发板的多颜色三角形识别程序,能够检测红、绿、蓝三种颜色的三角形。程序使用摄像头获取实时图像,通过LAB颜色阈值过滤识别特定颜色的色块,并判断是否为三角形(通过检测4个角点)。识别到…

作者头像 李华