今天配置swagger的时候出现了一个小问题,检查了很多地方都没问题,就是访问不到swagger页面,后来查看了很多文章发现是springBoot静态资源配置问题。
这是swagger静态资源存放路径:
由上图可以发现,如果我们的项目添加了静态资源相关的配置,那么就需要吧swagger的静态资源路径也添加进去
1. 错误配置方式:
#静态资源访问路径
spring.mvc.static-path-pattern: /static/**
#静态资源所在路径
spring.mvc.resources.static-locations: classpath:/static/,classpath:/public/
static-locations可以有多个值,而static-path-pattern只能有一个值,如果想要swagger能正常访问,只能把访问路径这样设置:
#静态资源访问路径
spring.mvc.static-path-pattern: /**
#静态资源所在路径
spring.mvc.resources.static-locations: classpath:/static/,classpath:/public/,classpath:/META-INF/resources/,classpath:/META-INF/resources/webjars/
但是这样的话,项目的静态资源就访问不到了(页面报 404),使用,改为配置类的方式配置;
2.正确的静态资源配置:
/**
* Spring MVC 配置
*/
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
/**
* 配置静态资源访问路径
*/
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
// 静态资源访问路径和存放路径配置
registry.addResourceHandler("/static/**").addResourceLocations("classpath:/static/","classpath:/public/");
// swagger访问配置
registry.addResourceHandler("/**").addResourceLocations("classpath:/META-INF/resources/","classpath:/META-INF/resources/webjars/");
}
}
如果还需要,在方法里面添加配置即可。