Spring Boot 静态资源映射

默认的静态资源目录

Spring Boot 中,默认的静态资源目录如下:

优先级(数字越小优先级越高) 类路径位置(在/src/main/resources/中对应的目录 说明
1 classpath:/META-INF/resources/ 常用于 WebJars,放在/META-INF/resources/下的文件会被直接映射。
2 classpath:/resources/ /src/main/resources/resources/对应,适合放置不想放在staticpublic的资源。
3 classpath:/static/ 最常用的静态资源目录,放在/src/main/resources/static/下的文件会映射到根路径(/**)。
4 classpath:/public/ static类似,放在/src/main/resources/public/下的文件同样可直接访问。

这些路径在 Spring Boot 3.x 中,由org.springframework.boot.autoconfigure.web.WebProperties.Resources.CLASSPATH_RESOURCE_LOCATIONS定义。


访问示例

文件实际路径 访问 URL
/src/main/resources/META-INF/resources/index.html http://localhost:8080/index.html
/src/main/resources/META-INF/resources/1/index.html http://localhost:8080/1/index.html
/src/main/resources/resources/index.html http://localhost:8080/index.html
/src/main/resources/resources/2/index.html http://localhost:8080/2/index.html
/src/main/resources/static/index.html http://localhost:8080/index.html
/src/main/resources/static/3/index.html http://localhost:8080/3/index.html
/src/main/resources/public/index.html http://localhost:8080/index.html
/src/main/resources/public/4/index.html http://localhost:8080/4/index.html

相关说明

  1. 不需要在 URL 中填写静态资源目录(如/META-INF/resources//resources//static//public/),Spring Boot 会自动把根路径映射到这些目录;

  2. 优先级:如果同名资源出现在多个目录,按/META-INF/resources/ -> /resources/ -> /static/ -> /public/的顺序决定最终返回的文件;

  3. 自定义:如果想改动默认位置,可在application.properties(或application.ymlapplication.yaml)中配置spring.web.resources.static-locations,该配置会覆盖默认值,也就是上述默认的静态资源目录将失效(由于 Spring Boot 的兜底机制,部分目录依然有效,具体说明见5),需要在该配置项显式配置,优先级也由该配置的顺序决定(越靠前优先级越高);

  4. 欢迎页(index.html):放在上述任意目录的根路径下,会被自动识别为默认首页;

  5. 由于 Spring Boot 的兜底机制,即便spring.web.resources.static-locations置空,或配置的自定义路径,没有配置上述的默认静态资源目录,其它默认配置会失效,/META-INF/resources/还是有效的,相当于会自动在该配置最后添加/META-INF/resources/,可通过配置spring.web.resources.add-mappings=false关闭兜底机制。


默认配置相关代码

org.springframework.boot.autoconfigure.web.WebProperties.Resources.CLASSPATH_RESOURCE_LOCATIONS相关源码如下:

java 复制代码
@ConfigurationProperties("spring.web")
public class WebProperties {
    // ...
    public static class Resources {
        private static final String[] CLASSPATH_RESOURCE_LOCATIONS = new String[]{"classpath:/META-INF/resources/", "classpath:/resources/", "classpath:/static/", "classpath:/public/"};
        private String[] staticLocations;
        private boolean addMappings;
        private boolean customized;
        private final Chain chain;
        private final Cache cache;

        public Resources() {
            this.staticLocations = CLASSPATH_RESOURCE_LOCATIONS;
            this.addMappings = true;
            this.customized = false;
            this.chain = new Chain();
            this.cache = new Cache();
        }

        public String[] getStaticLocations() {
            return this.staticLocations;
        }

        public void setStaticLocations(String[] staticLocations) {
            this.staticLocations = this.appendSlashIfNecessary(staticLocations);
            this.customized = true;
        }
        // ...
    }
    // ...
}
相关推荐
梦梦代码精7 小时前
《全栈开源智能体:终结企业AI拼图时代》
人工智能·后端·深度学习·小程序·前端框架·开源·语音识别
Victor3568 小时前
Hibernate(42)在Hibernate中如何实现分页?
后端
Victor3568 小时前
Hibernate(41)Hibernate的延迟加载和急加载的区别是什么?
后端
猪猪拆迁队8 小时前
2025年终总结-都在喊前端已死,这一年我的焦虑、挣扎与重组:AI 时代如何摆正自己的位置
前端·后端·ai编程
ConardLi8 小时前
SFT、RAG 调优效率翻倍!垂直领域大模型评估实战指南
前端·javascript·后端
Hooray9 小时前
2026年,站在职业生涯十字路口的我该何去何从?
前端·后端
唐叔在学习9 小时前
还在申请云服务器来传输数据嘛?试试P2P直连吧
后端·python
开心猴爷9 小时前
iOS 代码混淆在项目中的方式, IPA 级保护实践记录
后端
魅影骑士001010 小时前
柯里化函数
后端·设计模式
JOEH6010 小时前
🛡️ 微服务雪崩救星:Sentinel 限流熔断实战,3行代码搞定高可用!
后端·全栈