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

springboot静态资源的核心映射规则

SpringBoot 对静态资源的处理做了高度封装,核心围绕「默认资源位置」「访问路径映射」「自定义配置」三大维度设计,旨在简化静态资源(CSS/JS/ 图片 / 静态页面等)的访问与管理,以下是其核心映射规则的详细解析:

一、默认静态资源存放位置(优先级从高到低)

SpringBoot 启动时会自动扫描以下目录作为静态资源根路径,资源可直接通过「访问路径」访问,无需额外配置:

  1. classpath:/META-INF/resources/(常用于第三方 jar 包的静态资源)
  2. classpath:/resources/(项目核心静态资源目录)
  3. classpath:/static/(最常用,默认推荐存放目录)
  4. classpath:/public/(通用公共静态资源)

示例:在classpath:/static/下存放img/logo.png,可直接通过http://localhost:8080/img/logo.png访问。

二、默认访问路径映射规则

  1. 基础映射:默认情况下,静态资源的访问路径为「/**」,即所有未被控制器(@Controller/@RestController)匹配的请求,都会尝试从上述静态资源目录查找。
    • 例如:请求http://localhost:8080/js/index.js→ 匹配classpath:/static/js/index.js
  2. 欢迎页(首页)规则:SpringBoot 会自动查找静态资源目录下的index.html作为默认首页,访问http://localhost:8080/时直接返回该文件。
  3. favicon.ico 规则:自动查找静态资源目录下的favicon.ico作为网站图标,无需手动配置映射。

三、静态资源前缀配置(自定义访问路径)

若需给静态资源添加统一访问前缀(如/static/**),可通过配置修改映射规则:

1. SpringBoot 2.x/3.x 配置(application.yml)

yaml

spring: web: resources: # 静态资源访问前缀(需加/**) static-path-pattern: /static/** # 自定义静态资源根目录(可追加多个) locations: [classpath:/my-static/, classpath:/static/]

效果:访问http://localhost:8080/static/img/logo.png→ 匹配classpath:/my-static/img/logo.png(优先级更高)或classpath:/static/img/logo.png

四、静态资源缓存与版本控制

  1. 默认缓存策略:SpringBoot 对静态资源默认开启缓存(通过响应头Cache-Control),可通过配置调整缓存时长:

yaml

spring: web: resources: cache: # 缓存有效期(单位:秒) period: 3600
  1. 版本控制(防止缓存失效)
    • 方式 1:手动添加版本号(如js/index.js?v=1.0);
    • 方式 2:配置资源哈希版本(需结合 WebMvcConfig 自定义)。

五、静态资源禁用 / 优先级说明

  1. 禁用静态资源映射:若无需静态资源功能,可通过配置关闭:

yaml

spring: web: resources: add-mappings: false
  1. 控制器优先级高于静态资源:若控制器映射路径(如@GetMapping("/img/logo.png"))与静态资源路径冲突,优先执行控制器逻辑,不会访问静态资源。

六、核心底层逻辑(补充)

SpringBoot 静态资源映射的核心由WebMvcAutoConfiguration自动配置类实现,默认注册ResourceHttpRequestHandler处理静态资源请求,若自定义WebMvcConfigurer并重写addResourceHandlers方法,会覆盖默认规则(可实现更灵活的映射)。

自定义资源映射示例(代码层面)

java

运行

@Configuration public class WebConfig implements WebMvcConfigurer { @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { // 映射本地磁盘目录到访问路径 registry.addResourceHandler("/disk/**") .addResourceLocations("file:D:/static/"); } }

效果:访问http://localhost:8080/disk/img/photo.jpg→ 匹配本地D:/static/img/photo.jpg

http://www.cnnetsun.cn/news/33222.html

相关文章:

  • Pcileech-DMA-NAMe-VMD:颠覆传统数据传输的开源DMA终极方案
  • Readest页面动效系统:打造沉浸式数字阅读体验的5大核心技术
  • MacBook Touch Bar适配方案:从兼容性难题到完美体验
  • 告别传统GUI:用egui重新定义Rust应用界面开发
  • x-ray代码重构终极指南:如何优化复杂网页抓取逻辑
  • MicMac三维重建技术:从照片到专业级模型的智能转换方案
  • Android-Touch-Helper终极配置指南:5个简单步骤彻底告别开屏广告
  • OpenVINO Notebooks终极指南:快速掌握深度学习模型推理技术
  • AI图表生成终极指南:如何用自然语言一键创建专业图表
  • 爱普生L系列打印机清零解决方案:告别墨水计数烦恼
  • faster-whisper终极指南:实现毫秒级语音时间戳定位
  • GPT-5.2 深度技术解析:OpenAI 最强模型的架构与性能突破
  • 终极中文输入体验:東風破 plum 配置管理器全解析
  • Ant Design Blazor企业级开发终极指南:从选型到上线的完整解决方案
  • OpenCode自动化测试:AI驱动的代码质量保障体系
  • React useContextSelector终极指南:解决Context性能瓶颈的完整教程
  • ArkOS游戏掌机系统:从零开始打造你的专属游戏平台
  • DragGAN实战指南:零基础打造专属AI图像编辑平台
  • Control-LoRA技术革新:重塑AI图像生成的新范式
  • 初等数论陈景润PDF版:密码学必备的数学宝典
  • 如何快速获取1629个高质量书源?阅读3.0终极指南
  • Deep-Live-Cam人脸增强功能异常排查:从模糊到清晰的终极解决方案
  • 基于Spring Boot框架和vue的眼镜网红店订单系统 眼镜商城系统_821l4ouk
  • 基于springbooot的民宿预定管理系统_mp97e7if
  • Ender3V2S1专业固件完整配置指南:从入门到精通
  • 5个实用技巧彻底解决Captura音频录制质量问题
  • Shell脚本入门:让重复工作自动化
  • 下载burpsuite中遇到的常见问题及安装过程
  • 经典算法题详解之统计重复个数(一)
  • 5分钟掌握NeuTTS Air:嵌入式设备语音克隆终极指南