今天上班从svn代码库拉取新代码后,启动相应服务访问swagger文档报错404;
检查swagger配置没错,其他服务swagger都能访问,唯独这个服务不行。
想想估计是pom文件导入的新jar包可能和swagger访问路径有冲突
一.首先查看pom文件新增的jar包依赖
- 新增的依赖(maven管理)
<!--Ueditor富文本编辑器所需jar包-->
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
<version>1.9</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.json/json -->
<dependency>
<groupId>org.json</groupId>
<artifactId>json</artifactId>
<version>20160810</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
这里发现在学习springmvc时使用过的thymeleaf应该是有个前缀路径的,这时候去查看了maven的jar包依赖源码。
二.查看External libraries中maven管理的jar包
- 先查看springboot自动配置jar包依赖:
- 找到thymeleaf中的ThymeleafProperties就是默认配置
- 发现默认前缀是/templates,而swagger访问swagger-ui.html没有前缀,可能就会造成404.
三.解决方案
- 通过优秀的百度查找解决方式:
我的项目中当前服务有个配置类是继承的WebMvcConfigurationSupport,而查询到的是继承WebMvcConfigurer配置,两者应该是都有这个方法可以配置静态资源的处理,于是我就尝试了下。
我添加了如下代码后,swagger就能访问了:
2.添加的代码如下:
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("swagger-ui.html")
.addResourceLocations("classpath:/META-INF/resources/");
registry.addResourceHandler("/webjars/**")
.addResourceLocations("classpath:/META-INF/resources/webjars/");
}
感谢阅读,如果有什么问题,请批评指出,互相学习进步。
业精于勤而荒于嬉,行成于思而毁于随 – 韩愈