spring boot 静态资源处理方法

发布时间 - 2026-01-11 00:12:54    点击率:

spring boot 秉承约定优于配置,spring boot在静态资源的处理上就已经默认做了处理。

1.默认资源映射

映射”/**”的路径到 /static (或/public、/resources、/META-INF/resources), ”/webjars/** 映射到 classpath:/META-INF/resources/webjars/

复制代码 代码如下:
<script type="text/javascript" src="${request.contextPath }/js/index.js"></script>

注:若在freemarker获取request对象,在spring boot 在application.properties可以这么配置

spring.freemarker.request-context-attribute=request

2.如何自定义静态资源映射

spring boot有默认的资源映射,如果你觉得有需求需要,需要自己映射资源,可以在application.properties配置资源映射

#资源映射路径为/content/**
spring.mvc.static-path-pattern=/content/**
#资源映射地址为classpath:/content/
spring.resources.static-locations=classpath:/content/ 

配置了之后,默认资源映射失效,若要让默认的资源也有效的话,可以基于Java来配置

@Configuration
public class MvcConfiguration extends WebMvcConfigurerAdapter {

  @Override
  public void addResourceHandlers(ResourceHandlerRegistry registry) {
   registry.addResourceHandler("/myres/**").addResourceLocations("classpath:/myres/");
    super.addResourceHandlers(registry);
  }

}

这里不要用@EnableWebMvc,如果用了@EnableWebMvc,那sping boot默认关于webmvc的配置都会失效,你需要自己去配置每一项

3.配置webjars

webjars能允许我们利用java打包的方式,把web的资源文件打包成jar文件,并利用maven进行版本控制http://www.webjars.org/,在pom.xml中jQuery依赖

<dependency>
  <groupId>org.webjars</groupId>
  <artifactId>jquery</artifactId>
  <version>1.11.3</version>
</dependency>

引入成功之后,自动把资源放到classpath://META-INFO/resources/webjars目录下,我们可以通过/webjars/** 来访问

复制代码 代码如下:
<script type="text/javascript" src="${request.contextPath }/webjars/jquery/1.11.3/jquery.js"></script>

4.webjars资源版本控制

既然引入maven进行版本控制,当有新版本的web资源的时候,当然不希望一个个的去客户端修改资源版本号,我们利用WebJarAssetLocator来处理,首先在pom.xml引入依赖

<dependency>
  <groupId>org.webjars</groupId>
  <artifactId>webjars-locator</artifactId>
</dependency>

然后定义一个controller进行拦截

@Controller
public class WebJarsController {

  private final WebJarAssetLocator assetLocator = new WebJarAssetLocator();

  @ResponseBody
  @RequestMapping("/webjarslocator/{webjar}/**")
  public ResponseEntity<?> locateWebjarAsset(@PathVariable String webjar, HttpServletRequest request) {
    try {
      String mvcPrefix = "/webjarslocator/" + webjar + "/"; // This prefix must match the mapping path!
      String mvcPath = (String) request.getAttribute(HandlerMapping.PATH_WITHIN_HANDLER_MAPPING_ATTRIBUTE);
      String fullPath = assetLocator.getFullPath(webjar, mvcPath.substring(mvcPrefix.length()));
      return new ResponseEntity<>(new ClassPathResource(fullPath), HttpStatus.OK);
    } catch (Exception e) {
      return new ResponseEntity<>(HttpStatus.NOT_FOUND);
    }
  }
}

在页面上,就这么调用,不需要写具体版本号

复制代码 代码如下:
<script type="text/javascript" src="${request.contextPath }/webjarslocator/jquery/jquery.js"></script>

5.使用ResourceUrlProvider对自定义的静态资源进行管理

在使用第三方库,我们可以是使用WebJarAssetLocator的方式进行版本管理,但是使用自己写css和js,建议使用ResourceUrlProvider进行版本管理,并避免在版本发生改变时,由于浏览器缓存而产生资源版本未改变的错误

首先我们定义一个controller将路径信息推到前端

@ControllerAdvice
public class ResourceUrlProviderController {

  @Autowired
  private ResourceUrlProvider resourceUrlProvider;

  @ModelAttribute("urls")
  public ResourceUrlProvider urls() {
    return this.resourceUrlProvider;
  }

}

前端页面上,我们这么引入

复制代码 代码如下:
<script type="text/javascript" src="${request.contextPath }/${urls.getForLookupPath('/js/index.js')}"></script>

而实际上,在生成的html页面上,已加上md5的后缀

复制代码 代码如下:
<script type="text/javascript" src="/demo//js/index-a789359d91ae435bc45489c5e6978b34.js"></script>

由于ResourceUrlProvider监听了ApplicationListener<ContextRefreshedEvent>
所以在项目refresh的时候,在产生一个新的md5,这样客户端的资源路径就发生改变,回去服务器重新获取。

这就是spring boot的静态资源处理

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# spring  # boot  # 静态资源  # 静态页面  # 静态文件  # SpringBoot中的五种对静态资源的映射规则的实现  # SpringBoot web静态资源配置详解  # SpringBoot通过源码探究静态资源的映射规则实现  # SpringBoot配置外部静态资源映射问题  # 我们可以  # 自定义  # 客户端  # 这就是  # 用了  # 不需  # 第三方  # 若要  # 新版本  # 推到  # 不要用  # 大家多多  # 要写  # 如果你觉得  # 每一项  # 就这么  # 目录下  # 来访问  # jar  # WebMvcConfigurerAdapter 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  Python制作简易注册登录系统  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  Python并发异常传播_错误处理解析【教程】  如何在Windows虚拟主机上快速搭建网站?  微信小程序 input输入框控件详解及实例(多种示例)  装修招标网站设计制作流程,装修招标流程?  大型企业网站制作流程,做网站需要注册公司吗?  如何在阿里云ECS服务器部署织梦CMS网站?  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】  Laravel项目怎么部署到Linux_Laravel Nginx配置详解  如何在建站之星网店版论坛获取技术支持?  Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  如何用PHP工具快速搭建高效网站?  jQuery validate插件功能与用法详解  高防服务器租用如何选择配置与防御等级?  Android使用GridView实现日历的简单功能  Laravel如何升级到最新版本?(升级指南和步骤)  C语言设计一个闪闪的圣诞树  Angular 表单中正确绑定输入值以确保提交与验证正常工作  googleplay官方入口在哪里_Google Play官方商店快速入口指南  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  在Oracle关闭情况下如何修改spfile的参数  为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】  Java垃圾回收器的方法和原理总结  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  动图在线制作网站有哪些,滑动动图图集怎么做?  PythonWeb开发入门教程_Flask快速构建Web应用  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  Laravel如何创建自定义Facades?(详细步骤)  nodejs redis 发布订阅机制封装实现方法及实例代码  手机软键盘弹出时影响布局的解决方法  个人摄影网站制作流程,摄影爱好者都去什么网站?  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  Android GridView 滑动条设置一直显示状态(推荐)  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  JavaScript实现Fly Bird小游戏  Laravel怎么实现模型属性的自动加密  Laravel怎么使用Intervention Image库处理图片上传和缩放  Laravel如何使用Eloquent进行子查询  Laravel如何使用Service Container和依赖注入?(代码示例)  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  香港服务器选型指南:免备案配置与高效建站方案解析  Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤