默认静态资源路径
- classpath:/META-INF/resources/
- classpath:/resources/
- classpath:/static/
- classpath:/public/
静态资源路径下的文件,可以通过根目录访问
resources 文件夹的文件如下图所示:
data:image/s3,"s3://crabby-images/21937/2193763ba6b5f2b5f6f3bf41b11b8d89eb0bdc85" alt=""
启动项目,分别访问以下路径:
- http://localhost:8080/a.jpeg
- http://localhost:8080/b.jpeg
- http://localhost:8080/c.jpeg
- http://localhost:8080/d.jpeg
data:image/s3,"s3://crabby-images/5a9fc/5a9fc383bb5ea48d282ab24777406ed0e560de28" alt=""
data:image/s3,"s3://crabby-images/1f4ce/1f4cede0bd717b60721486f5f323f4b132039c99" alt=""
data:image/s3,"s3://crabby-images/90ed4/90ed4ef37177d61d92ba88cabd23e7488e765f80" alt=""
data:image/s3,"s3://crabby-images/204e5/204e5cf0679257e781be9477e0c6b75bfa6b207d" alt=""
默认路径下的静态资源都可以访问
优先级问题
如果一个 Controller 的路径映射和静态资源的路径一致,Controller的优先级更高,案例演示如下:
@RestController
public class JpegController {
@GetMapping("/a.jpeg")
public String getJpeg() {
return "a.jpeg";
}
}
data:image/s3,"s3://crabby-images/49039/49039c40ec7065d5d9f966896af585ac28dafecd" alt=""
欢迎页
如果静态资源路径下存在 index.html,访问项目的根目录会映射到 index.html
分别给四个默认静态资源路径下创建 index.html,每个 index.html 文件只存在一个h1标签,h1标签内容为静态资源路径名称,相关内容如下所示:
data:image/s3,"s3://crabby-images/b8bea/b8bea774f2ddf4931e470b135459b4c1629356b3" alt=""
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>classpath:/META-INF/resources/</h1>
</body>
</html>
1.访问项目的根目录
data:image/s3,"s3://crabby-images/84db4/84db4b4a2766cf7acd5a55a522c9d73002380f4f" alt=""
2.删除 /META-INF/resources/ 路径下的 index.html,重启项目,访问项目的根目录
data:image/s3,"s3://crabby-images/7248d/7248d3120e99f97c6ff9b1ef0f8d52cd8c2f94ad" alt=""
3.删除 /resources/ 路径下的 index.html,重启项目,访问项目的根目录
data:image/s3,"s3://crabby-images/f0246/f0246d785882a738f944840587f1246ce9c70d1c" alt=""
4.删除 /static/ 路径下的 index.html,重启项目,访问项目的根目录
data:image/s3,"s3://crabby-images/0b631/0b631bad8c15b5adba8f5da819a6052995cc10f6" alt=""
综上所述,默认静态资源的优先级如下:
- classpath:/META-INF/resources/
- classpath:/resources/
- classpath:/static/
- classpath:/public/
使用 thymeleaf
引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
<version>2.6.13</version>
</dependency>
创建 templates 文件夹,并在文件夹下创建 index.html
data:image/s3,"s3://crabby-images/f9de5/f9de568ffbe3347145f01b2b9a8acf62f0a0ad71" alt=""
访问项目的根目录
data:image/s3,"s3://crabby-images/df453/df453ab1fa62b5184af13b5411d73a875924d9c6" alt=""
默认静态资源形式的欢迎页的优先级高于 thymeleaf 形式的欢迎页
自定义静态资源访问前缀
我们在开发的过程中,可能会使用拦截器拦截(放行)指定路径的资源,所以需要指定前缀
自定义静态资源访问前缀为 /res/**
spring:
mvc:
static-path-pattern: /res/**
演示静态资源的访问
访问路径 http://localhost:8080/b.jpeg
data:image/s3,"s3://crabby-images/9cb77/9cb77850e7bc9790146019aa1520efa5cddfe989" alt=""
加上自定义前缀 /res/** ,访问路径 http://localhost:8080/res/b.jpeg
data:image/s3,"s3://crabby-images/0a689/0a689c23999f7997236234425fc83859f7e26de3" alt=""
自定义静态资源访问前缀会导致默认静态资源形式的欢迎页功能失效
自定义静态资源路径
spring:
mvc:
static-path-pattern: /res/**
web:
resources:
static-locations: [classpath:/custom_static/]
访问路径 http://localhost:8080/res/b.jpeg
data:image/s3,"s3://crabby-images/95197/9519760599f7e67ee080d581d630c499341bb128" alt=""
将 /resources/ 下的 b.jpeg 移动到 /custom_static/ 下,重启项目, 再次访问路径 http://localhost:8080/res/b.jpeg
data:image/s3,"s3://crabby-images/371be/371beb7b4d08c23f6763282059614e687e6a15f5" alt=""
WebJars
WebJars 以 Jar 形式为 Web 项目提供资源文件
官方网址 : WebJars - Web Libraries in Jars
使用步骤
1.引入pom文件
data:image/s3,"s3://crabby-images/5132f/5132fabf96f2763260dfa231be0900b6e3105c9d" alt=""
2.查看 jar 包中静态文件路径
data:image/s3,"s3://crabby-images/aea49/aea497e206eae502eecf9da021c47530993b343f" alt=""
3.访问http://localhost:8080/webjars/jquery/3.7.1/jquery.js
data:image/s3,"s3://crabby-images/07bff/07bff756ac0a9bbb52506f66ae2a8b4457849af3" alt=""
禁用静态资源规则
spring:
web:
resources:
add-mappings: false
访问默认静态资源形式的欢迎页失效
访问静态资源路径文件失效
data:image/s3,"s3://crabby-images/cd97b/cd97b4838d041d59e6c5982e5dd9f166d1b88c27" alt=""
访问Webjars文件相关路径失效
data:image/s3,"s3://crabby-images/aa9ef/aa9ef5206a0d97bb7a552d86fc28172c88c9f948" alt=""
add-mappings 属性只能禁用默认的静态资源规则,手动定义的相关配置任然有效
1.创建配置文件WebConfig
@Configuration
public class WebConfig implements WebMvcConfigurer {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/stc/**")
.addResourceLocations("classpath:/aa/");
}
}
2.将 a.jpeg 移动到 aa 文件夹下
3.访问路径 http://localhost:8080/stc/a.jpeg
data:image/s3,"s3://crabby-images/945cd/945cdfa2e768f4f64b7f5ec45075bc925c1799f2" alt=""
源码简析
默认静态资源的定义
WebProperties.Resources#CLASSPATH_RESOURCE_LOCATIONS
data:image/s3,"s3://crabby-images/61060/610609e3b0806a77c8709a792b822aa2863f37a0" alt=""
欢迎页
优先级问题
EnableWebMvcConfiguration#getWelcomePage
data:image/s3,"s3://crabby-images/c6525/c6525f003d777a487bc835689e95206827545134" alt=""
其中 this.resourceProperties.getStaticLocations() 就是 WebProperties.Resources#CLASSPATH_RESOURCE_LOCATIONS 或者自定义的静态资源路径。默认情况下,路径 classpath:/META-INF/resources/ 是数组第一个,所以优先级最高
自定义静态资源访问前缀,默认静态资源形式的欢迎页失效问题
data:image/s3,"s3://crabby-images/9d580/9d5804ef091bdc5460bc8a99e03d66c52e8f0124" alt=""
data:image/s3,"s3://crabby-images/96981/96981b39bd0d448bde1cb9463b8a007ace88e0de" alt=""
WebMvcProperties 的 staticPathPattern 属性的默认值为 /**,如果我们自定义了静态资源访问前缀该默认值就会被替换,就不会进入 if 分支,所以默认静态资源形式的欢迎页失效
thymeleaf 形式的欢迎页相关源码
data:image/s3,"s3://crabby-images/a8c06/a8c0689ca3a60a891d8bafdec4abee73a5e39756" alt=""
data:image/s3,"s3://crabby-images/d94a1/d94a1497ab054d2e7532401d8bb8e6f4146a6f76" alt=""
相关属性的默认值:
- view : index
- prefix : classpath:/templates/
- suffix:.html
所以 thymeleaf 形式的欢迎页的默认路径就是 classpath:/templates/index.html ,我们可以通过 spring.thymeleaf.prefix 、spring.thymeleaf.suffix 属性指定前缀和后缀
禁用静态资源规则
WebMvcAutoConfigurationAdapter#addResourceHandlers
data:image/s3,"s3://crabby-images/44864/44864961b3fe78f9e5d52eb2efc9006002e9abf1" alt=""
- this.mvcProperties.getStaticPathPattern() :默认或者自定义静态资源访问前缀
- this.resourceProperties.getStaticLocations() :默认或者自定义静态资源路径
如果 WebProperties.Resources#addMappings 属性为 false,则不添加 webjars 和 静态资源相关ResourceHandler
自定义静态资源访问前缀和禁用静态资源规则都不影响 thymeleaf 形式的欢迎页功能