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提供了默认的支持。
相关推荐
钱多多_qdd3 分钟前
spring cache源码解析(四)——从@EnableCaching开始来阅读源码
java·spring boot·spring
waicsdn_haha5 分钟前
Java/JDK下载、安装及环境配置超详细教程【Windows10、macOS和Linux图文详解】
java·运维·服务器·开发语言·windows·后端·jdk
飞的肖13 分钟前
前端使用 Element Plus架构vue3.0实现图片拖拉拽,后等比压缩,上传到Spring Boot后端
前端·spring boot·架构
Q_192849990615 分钟前
基于Spring Boot的摄影器材租赁回收系统
java·spring boot·后端
Code_流苏17 分钟前
VSCode搭建Java开发环境 2024保姆级安装教程(Java环境搭建+VSCode安装+运行测试+背景图设置)
java·ide·vscode·搭建·java开发环境
良许Linux19 分钟前
0.96寸OLED显示屏详解
linux·服务器·后端·互联网
求知若饥31 分钟前
NestJS 项目实战-权限管理系统开发(六)
后端·node.js·nestjs
禁默1 小时前
深入浅出:AWT的基本组件及其应用
java·开发语言·界面编程
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
Code哈哈笑1 小时前
【Java 学习】深度剖析Java多态:从向上转型到向下转型,解锁动态绑定的奥秘,让代码更优雅灵活
java·开发语言·学习