news 2026/5/1 10:53:16

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 4:06:17

Vue-ECharts终极指南:5分钟学会在Vue中构建专业数据可视化图表

Vue-ECharts终极指南:5分钟学会在Vue中构建专业数据可视化图表 【免费下载链接】vue-echarts 项目地址: https://gitcode.com/gh_mirrors/vue/vue-echarts Vue-ECharts是一个强大的Vue.js组件库,专门为在Vue应用中集成Apache ECharts™数据可视化…

作者头像 李华
网站建设 2026/5/1 4:05:04

如何快速批量下载网络图片:Image-Downloader终极使用指南

还在为一张张手动保存网络图片而烦恼吗?Image-Downloader这款Python图片批量下载工具,将彻底改变你的工作方式。无论是设计师寻找灵感素材,还是研究人员构建图像数据集,这款免费图片采集工具都能提供专业级的解决方案。 【免费下载…

作者头像 李华
网站建设 2026/5/1 4:06:14

2025 ResNet50进化:从医疗诊断到工业质检的精度与效率革命

导语 【免费下载链接】resnet_50 ResNet50 model pre-trained on ImageNet-1k at resolution 224x224. 项目地址: https://ai.gitcode.com/openMind/resnet_50 ResNet50架构在2025年迎来重大升级,通过A1训练配方实现81.22%的ImageNet Top-1准确率&#xff0c…

作者头像 李华
网站建设 2026/5/1 7:19:14

唱音分析法

唱音分析法 唱音分析法是把音节分析成唱音序列的方法。在节调质素音节中,与质素联结的调段准确地说是与质素相联结的构成节调的调段的简称。在把音节分析成由唱音构成的音列后,唱音是由质素和与其相联结的调段构成的音段。唱音的音质是充当声母的质素和…

作者头像 李华
网站建设 2026/5/1 0:27:21

深度解析:自动驾驶感知模型快速跨场景部署实战指南

深度解析:自动驾驶感知模型快速跨场景部署实战指南 【免费下载链接】transferlearning Transfer learning / domain adaptation / domain generalization / multi-task learning etc. Papers, codes, datasets, applications, tutorials.-迁移学习 项目地址: http…

作者头像 李华
网站建设 2026/5/1 5:04:49

串口调试新体验:唐老鸭版助你轻松搞定嵌入式开发

串口调试新体验:唐老鸭版助你轻松搞定嵌入式开发 【免费下载链接】串口助手唐老鸭版使用说明 串口助手(唐老鸭版)是一款功能强大且易于使用的串口调试工具,专为开发者设计。其界面友好,操作简单,能够满足各种串口调试需求。无论是…

作者头像 李华