Spring Boot 开发 -- 静态资源配置详解

一、引言

在开发Web应用程序时,静态资源的管理和配置是一个重要的环节。Spring Boot框架为开发者提供了便捷的静态资源配置方式,使得我们可以轻松地管理如HTML、CSS、JavaScript、图片等静态资源。本文将详细介绍如何在Spring Boot项目中配置和管理静态资源。

二、Spring Boot 静态资源默认配置

Spring Boot 默认提供了静态资源的映射位置,主要包括以下几个目录:

  • /static
  • /public
  • /resources
  • /META-INF/resources
    当我们把静态资源文件放在这些目录下时,Spring Boot会自动为它们提供HTTP访问。例如,如果我们有一个名为index.html的文件放在/static目录下,那么我们就可以通过http://localhost:8080/index.html来访问它。

三、自定义静态资源位置

虽然Spring Boot提供了默认的静态资源位置,但有时候我们可能需要自定义静态资源的位置。这可以通过配置spring.resources.static-locations属性来实现。例如,我们可以在application.properties或application.yml文件中添加以下配置:

yaml 复制代码
# application.properties  
spring.resources.static-locations=classpath:/custom-static/

或者

yaml 复制代码
# application.yml  
spring:
  resources:
    static-locations: classpath:/custom-static/

这样,Spring Boot就会从custom-static目录(位于类路径下)加载静态资源。

四、添加资源处理器

对于更复杂的静态资源需求,我们可以使用Spring MVC的ResourceHandler和ResourceResolver来定制资源处理方式。例如,我们可以为特定的URL模式添加自定义的资源处理器:

java 复制代码
@Configuration
public class ResourcesConfig implements WebMvcConfigurer {

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        /** swagger配置 */
        registry.addResourceHandler("swagger-ui.html")
        .addResourceLocations("classpath:/META-INF/resources/");
        // 配置Webjars资源位置  
        registry.addResourceHandler("/webjars/**").
        addResourceLocations("classpath:/META-INF/resources/webjars/");
        // 配置静态资源位置  
        registry.addResourceHandler("/static/**")  
                .addResourceLocations("classpath:/static/");  
        //自定义资源路径
        registry.addResourceHandler("/myresources/**")  
                .addResourceLocations("classpath:/my-custom-resources/");
    }

在上面的配置中,我们为以/myresources/开头的URL模式添加了一个资源处理器,它将从my-custom-resources目录(位于类路径下)加载静态资源。

五、注意事项

  1. 静态资源的访问路径是相对于应用的根路径(即/),而不是相对于静态资源所在的目录。
  2. 当有多个静态资源目录时,Spring Boot会按照默认配置的顺序(/static、/public、/resources、/META-INF/resources)来查找资源。如果找到了匹配的资源,就会立即返回该资源,不会继续查找其他目录。
  3. 如果需要访问Webjars中的资源(如jQuery、Bootstrap等),可以直接通过/webjars/**来访问。Spring Boot已经为Webjars提供了默认的支持。
相关推荐
gadiaola29 分钟前
【JVM】Java虚拟机(二)——垃圾回收
java·jvm
coderSong25683 小时前
Java高级 |【实验八】springboot 使用Websocket
java·spring boot·后端·websocket
Mr_Air_Boy4 小时前
SpringBoot使用dynamic配置多数据源时使用@Transactional事务在非primary的数据源上遇到的问题
java·spring boot·后端
豆沙沙包?4 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
年老体衰按不动键盘5 小时前
快速部署和启动Vue3项目
java·javascript·vue
咖啡啡不加糖5 小时前
Redis大key产生、排查与优化实践
java·数据库·redis·后端·缓存
liuyang-neu5 小时前
java内存模型JMM
java·开发语言
大鸡腿同学5 小时前
纳瓦尔宝典
后端
UFIT5 小时前
NoSQL之redis哨兵
java·前端·算法
刘 大 望5 小时前
数据库-联合查询(内连接外连接),子查询,合并查询
java·数据库·sql·mysql