当前位置: 首页 > article >正文

[Java实战]Spring Boot 静态资源配置(十三)

[Java实战]Spring Boot 静态资源配置(十三)

引言

静态资源(如 HTML、CSS、JavaScript、图片等)是 Web 应用的基石。Spring Boot 通过自动化配置简化了静态资源管理,但面对复杂场景(如多模块项目、CDN 集成、缓存优化)时,开发者仍需深入理解其工作原理。本文将系统解析 静态资源加载机制自定义配置技巧性能优化方案,并提供企业级实战案例。

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

1. 默认资源路径与优先级

Spring Boot 自动映射以下目录中的静态资源(按优先级排序):

目录说明示例路径
classpath:/META-INF/resources/Jar 包内资源src/main/resources/META-INF/resources/logo.png
classpath:/resources/标准资源目录src/main/resources/resources/css/style.css
classpath:/static/常用静态资源目录src/main/resources/static/js/app.js
classpath:/public/公共资源目录src/main/resources/public/images/banner.jpg

访问规则

  • 所有资源映射到 /** 路径。
  • 示例:static/js/app.jshttp://localhost:8080/js/app.js

2. 默认首页(Welcome Page)

Spring Boot 自动识别以下位置的 index.html 作为首页:

classpath:/META-INF/resources/index.html
classpath:/resources/index.html
classpath:/static/index.html
classpath:/public/index.html

二、自定义静态资源配置

1. 修改默认资源路径

application.yml 中覆盖默认配置:

spring:web:resources:static-locations: - classpath:/assets/     # 自定义目录- file:/opt/static/      # 外部目录(优先级高于 classpath)

2. 添加额外资源路径

通过 WebMvcConfigurer 扩展:

@Configuration
public class WebConfig implements WebMvcConfigurer {@Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {registry.addResourceHandler("/custom/**")  // 访问路径.addResourceLocations("classpath:/custom-static/", "file:/data/static/") // 资源位置.setCacheControl(CacheControl.maxAge(30, TimeUnit.DAYS)); // 缓存策略}
}

三、高阶配置与性能优化

1. 资源版本控制(防缓存)

为资源添加哈希版本,避免浏览器缓存旧文件:

spring:web:resources:chain:strategy:content:enabled: truepaths: /static/**   # 对 /static 下的文件启用版本控制

访问路径将变为:/static/js/app-abc123.js

2. 资源压缩(Gzip/Brotli)

启用响应压缩,减少传输体积:

server:compression:enabled: truemime-types: text/html,text/css,application/javascriptmin-response-size: 1024

3. CDN 集成

将静态资源托管到 CDN,提升访问速度:

@Configuration
public class CdnConfig {@Value("${cdn.host}")private String cdnHost;@Beanpublic ResourceUrlEncodingFilter resourceUrlEncodingFilter() {return new ResourceUrlEncodingFilter();}@Beanpublic ResourceUrlProvider resourceUrlProvider() {ResourceUrlProvider urlProvider = new ResourceUrlProvider();urlProvider.setHandlerMap(Collections.singletonMap("/static/**", new CdnResourceResolver(cdnHost)));return urlProvider;}
}

四、企业级实战案例

案例 1:多模块项目资源管理

项目结构

parent-project
├── core-module(业务逻辑)
└── web-module(Web 层)└── src/main/resources└── static└── web-module  # 模块隔离资源

配置

# web-module 的 application.yml
spring:web:resources:static-locations: classpath:/static/web-module/

案例 2:动态主题切换

根据用户选择加载不同主题的 CSS:

<link th:href="@{/themes/${user.theme}/style.css}" rel="stylesheet">

目录结构

static
└── themes├── default│   └── style.css└── dark└── style.css

五、常见问题与解决方案

1. 静态资源 404 错误

  • 排查步骤
    1. 检查文件是否在配置的 static-locations 路径中。
    2. 确认访问 URL 与资源路径匹配(注意大小写)。
    3. 清除浏览器缓存或使用无痕模式测试。

2. 缓存导致资源未更新

  • 解决方案
    • 启用版本控制(内容哈希)。
    • 强制刷新:Ctrl + F5(Windows)或 Cmd + Shift + R(Mac)。

3. 安全限制

Spring Security 放行静态资源

@Configuration
@EnableWebSecurity
public class SecurityConfig {@Beanpublic SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {http.authorizeRequests().requestMatchers("/static/**", "/public/**").permitAll().anyRequest().authenticated();return http.build();}
}

六、总结与最佳实践

  1. 目录规范:按类型组织资源(如 /static/css/static/js)。
  2. 环境区分:开发环境禁用缓存,生产环境启用压缩和版本控制。
  3. 监控优化:使用工具(如 Lighthouse)分析资源加载性能。
  4. 安全防护:避免敏感文件暴露在静态目录中。

扩展思考:如何结合 Spring Boot 与 WebAssembly 实现高性能前端?欢迎评论区探讨!

附录

  • Spring Boot 资源处理官方文档
  • HTTP 缓存策略详解(MDN)

希望本教程对您有帮助,请点赞❤️收藏⭐关注支持!欢迎在评论区留言交流技术细节!

相关文章:

[Java实战]Spring Boot 静态资源配置(十三)

[Java实战]Spring Boot 静态资源配置&#xff08;十三&#xff09; 引言 静态资源&#xff08;如 HTML、CSS、JavaScript、图片等&#xff09;是 Web 应用的基石。Spring Boot 通过自动化配置简化了静态资源管理&#xff0c;但面对复杂场景&#xff08;如多模块项目、CDN 集成…...

重生之我在2024学Fine-tuning

一、Fine-tuning&#xff08;微调&#xff09;概述 Fine-tuning&#xff08;微调&#xff09;是机器学习和深度学习中的一个重要概念&#xff0c;特别是在预训练模型的应用上。它指的是在模型已经通过大量数据训练得到一个通用的预训练模型后&#xff0c;再针对特定的任务或数据…...

Selenium Web自动化测试学习笔记(一)

自动化测试 技术手段模拟人工&#xff0c;执行重复性任务&#xff0c;准确率100%&#xff0c;高于人工 selenium 可通过浏览器驱动控制浏览器&#xff0c;通过元素定位模拟人工&#xff0c;实现web自动化&#xff0c;没有焦点&#xff08;把浏览器放在最小化依然可以&#x…...

2025年5月15日前 免费考试了! Oracle AI 矢量搜索专业​​认证

2025年5月5日前 免费考试了&#xff01; Oracle AI 矢量搜索专业​​认证 立刻预约吧 文章目录 2025年5月5日前 免费考试了&#xff01; Oracle AI 矢量搜索专业​​认证立刻预约吧&#x1f50d; 探索 AI 向量搜索的强大功能&#xff01;&#x1f3af; 学习路径目标&#x1f6e…...

服务器不备案有影响吗

在当今数字化的时代&#xff0c;服务器成为了众多企业和个人开展业务、展示自我的重要工具。然而&#xff0c;有一个问题常常被忽视&#xff0c;那就是服务器不备案到底有没有影响&#xff1f; 答案是肯定的&#xff01;服务器不备案&#xff0c;影响可不小。据相关数据显示&a…...

EasyRTC嵌入式音视频通话SDK驱动智能硬件音视频应用新发展

一、引言 在数字化浪潮下&#xff0c;智能硬件蓬勃发展&#xff0c;从智能家居到工业物联网&#xff0c;深刻改变人们的生活与工作。音视频通讯作为智能硬件交互与协同的核心&#xff0c;重要性不言而喻。但嵌入式设备硬件资源受限&#xff0c;传统音视频方案集成困难。EasyRT…...

力扣-21.合并两个有序链表

题目描述 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 class Solution { public:ListNode *mergeTwoLists(ListNode *list1, ListNode *list2) {ListNode *l new ListNode(-1);ListNode *p l;while (list1 &&…...

多线服务器具有什么优势

在当今数字化飞速发展的时代&#xff0c;多线服务器宛如一位低调的幕后英雄&#xff0c;默默为我们的网络世界提供着强大的支持。那么&#xff0c;多线服务器到底具有哪些令人瞩目的优势呢 首先&#xff0c;多线服务器的最大优势之一就是网络访问的高速与稳定。想象一下&#x…...

ESP32 PWM音频应用及场景说明

ESP32芯片的PWM&#xff08;脉冲宽度调制&#xff09;功能在音频应用中具有广泛用途&#xff0c;尤其是在低成本、低功耗的场景中。以下是具体的应用举例和应用场景说明&#xff1a; 一、ESP32 PWM音频应用举例 1. 简单音频播放 实现方式&#xff1a;通过PWM生成模拟音频信号&…...

C++.变量与数据类型

C++变量与数据类型 1. C++变量与数据类型1.1 基本数据类型1.2 复合数据类型2.1 定义方式2.2 常量类型3.1 数据类型修饰符3.2 存储类修饰符3.3 类访问修饰符4.1 算术运算符4.2 关系运算符4.3 逻辑运算符4.4 赋值运算符4.5 条件运算符4.6 位运算符5. 总结5.1 变量与数据类型5.2 常…...

Compose笔记(二十二)--NavController

这一节主要了解一下Compose中的NavController&#xff0c;它是实现导航功能的核心组件&#xff0c;提供了强大而灵活的页面管理能力&#xff0c;用于管理导航图中的目的地和执行导航操作。 API navigate(route: String) 含义&#xff1a;导航到指定路由的目的地。 作用&#x…...

SQL:SELF JOIN(自连接)与CROSS JOIN(交叉连接)

目录 SELF JOIN&#xff08;自连接&#xff09; CROSS JOIN&#xff08;交叉连接 / 笛卡尔积&#xff09; 示例&#xff1a; SELF JOIN CROSS JOIN 如果没有 DATEDIFF() 函数怎么办&#xff1f; &#x1f50d; SELF JOIN vs CROSS JOIN 对比总结 SELF JOIN&#xff08;自…...

互联网大厂Java求职面试:基于RAG的智能问答系统设计与实现-1

互联网大厂Java求职面试&#xff1a;基于RAG的智能问答系统设计与实现-1 场景背景 在某互联网大厂的技术面试中&#xff0c;技术总监张总正在面试一位名为郑薪苦的求职者。郑薪苦虽然对技术充满热情&#xff0c;但回答问题时总是带着幽默感&#xff0c;有时甚至让人哭笑不得。…...

Ubuntu 22.04.5 LTS 基于 kubesphere 安装 cube studio

Ubuntu 22.04.5 LTS 基于 kubesphere 安装 cube studio 前置条件 已经成功安装 kubesphere v4.3.1 参考教程: https://github.com/data-infra/cube-studio/wiki/%E5%9C%A8-kubesphere-%E4%B8%8A%E6%90%AD%E5%BB%BA-cube-studio 1. 安装基础依赖 # ubuntu安装基础依赖 apt insta…...

1.短信登录

1.0 问题记录 1.0.1 redis 重复 token 问题 每次用户登录时&#xff0c;后端会创建一个新的 token 并存入 Redis&#xff0c;但之前登录的 token 还没有过期。这可能会导致以下问题&#xff1a; 1. Redis 中存在大量未过期但实际已不使用的 token2. 同一用户可能有多个有效 …...

Linux-Ubuntu安装Stable Diffusion Forge

SD Forge在Win上配置起来相对简单且教程丰富&#xff0c;而在Linux平台的配置则稍有门槛且教程较少。本文提供一个基于Ubuntu24.04发行版&#xff08;对其他Linux以及SD分支亦有参考价值&#xff09;的Stable Diffusion ForgeUI安装配置教程&#xff0c;希望有所帮助 本教程以N…...

MixTeX - 支持CPU推理的多模态LaTeX OCR

文章目录 一、项目概览相关资源核心特性技术特点 二、安装三、使用说明环境要求 四、版本更新五、当前限制 一、项目概览 MixTeX是一款创新的多模态LaTeX识别小程序&#xff0c;支持本地离线环境下的高效CPU推理。 无论是LaTeX公式、表格还是混合文本&#xff0c;MixTeX都能轻…...

生成了一个AI算法

import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms # 1. 数据预处理 transform transforms.Compose([ transforms.ToTensor(), transforms.Normalize((0.5,), (0.5,)) # MNIST单通道归一化 ]) train_da…...

23、DeepSeek-V2论文笔记

DeepSeek-V2 1、背景2、KV缓存优化2.0 KV缓存&#xff08;Cache&#xff09;的核心原理2.1 KV缓存优化2.2 性能对比2.3 架构2.4多头注意力 &#xff08;MHA&#xff09;2.5 多头潜在注意力 &#xff08;MLA&#xff09;2.5.1 低秩键值联合压缩 &#xff08;Low-Rank Key-Value …...

关键字where

C# 中的 where 关键字主要用在泛型约束&#xff08;Generic Constraints&#xff09;中&#xff0c;目的是对泛型类型参数限制其必须满足的条件&#xff0c;从而保证类型参数具备特定的能力或特性&#xff0c;增强类型安全和代码可读性。 约束写法说明适用场景举例C#版本要求w…...

【算法专题十一】字符串

文章目录 1. leetcode.14.最长公共前缀1.1 题目1.2 思路1.3 代码 2. leetcode.5.最长回文字串2.1 题目2.2 思路2.3 代码 3. leetcode.67.二进制求和3.1 题目3.2 思路3.3 代码 4. leetcode.43.字符串相乘4.1 题目4.2 思路4.3 代码 1. leetcode.14.最长公共前缀 1.1 题目 题目链…...

美化IDEA注释:Idea 中快捷键 Ctrl + / 自动注释的缩进(避免添加注释自动到行首)以及 Ctrl + Alt + l 全局格式化代码的注释缩进

打开 Settings 界面&#xff0c;依次选择 Editor -> Code Style -> Java&#xff0c;选择 Code Generation&#xff0c; 取消 Line comment at first column 和 Block comment at first column 的勾选即可&#xff0c; 1、Line comment at first column (行注释在第一列…...

如何为APP应用程序选择合适的服务器

搭建一个成功的APP应用程序&#xff0c;服务器选择是至关重要的决策之一。合适的服务器不仅能确保应用流畅运行&#xff0c;还能节省成本并保障安全性。本文将为您详细解析如何为APP选择最佳服务器方案。 一、了解您的APP需求 在选择服务器前&#xff0c;首先需要明确您的应用…...

赛灵思 XCZU11EG-2FFVC1760I XilinxFPGAZynq UltraScale+ MPSoC EG

XCZU11EG-2FFVC1760I 是 Zynq UltraScale MPSoC EG 系列中性能最强的器件之一&#xff0c;集成了四核 ARM Cortex-A53 应用处理器、双核 Cortex-R5 实时处理器与 Mali-400 MP2 GPU&#xff0c;并结合了 653,100 个逻辑单元与丰富的片上存储资源&#xff0c;可满足高性能计算、A…...

Android Camera HAL v3 and Video4Linux 2

《小驰行动派的知识星球》 ———————————————— 推荐阅读&#xff1a; 关于博主 《小驰Camera私房菜》小册目录 采用v4l2loopback来实现 虚拟Camera Camera基础及一些基本概念 Android Camera 学习路线 | 个人推荐 Android Camera开发系列&#xff08;干货满满&a…...

基于pyqt的上位机开发

目录 安装依赖 功能包含 运行结果 安装依赖 pip install pyqt5 pyqtgraph pyserial 功能包含 自动检测串口设备&#xff0c;波特率选择/连接断开控制&#xff0c;数据发送/接收基础框架&#xff0c;实时绘图区域&#xff08;需配合数据解析&#xff09; ""&q…...

WHAT - Rust 智能指针

文章目录 常见的智能指针类型1. Box<T> — 堆上分配的数据2. Rc<T> — 引用计数的共享所有权&#xff08;单线程&#xff09;3. Arc<T> — 原子引用计数&#xff08;多线程&#xff09;4. RefCell<T> — 运行时可变借用&#xff08;单线程&#xff09;…...

CentOS 7 系统下安装 OpenSSL 1.0.2k 依赖问题的处理

前面有提到过这个openssl的版本冲突问题&#xff0c;也是在这次恢复服务器时遇到的问题&#xff0c;我整理如下&#xff0c;供大家参考。小小一个软件的安装&#xff0c;挺坑的。 一、问题 项目运行环境需要&#xff0c;指定PHP7.0.9这个版本&#xff0c;但是‌系统版本与软件…...

vue修改了node_modules中的包,打补丁

1、安装patch npm i patch-package 安装完成后&#xff0c;会在package.json中显示版本号 2、在package.json的scripts中增加配置 "postinstall": "patch-package" 3、执行命令 npx patch-package 修改的node_modules中的包的名称 像这样 npx patch-packag…...

[matlab]private和+等特殊目录在新版本matlab中不允许添加搜索路径解决方法

当我们目录包含有private,或者时候matlab搜索目录不让添加&#xff0c;比如截图&#xff1a; 在matlab2018以前这些都可以加进去后面版本都不行了。但是有时候我们必须要加进去才能兼容旧版本matlab库&#xff0c;比如mexopencv库就是这种情况。因此我们必须找到一个办法加进去…...