Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >SpringBoot2.x基础篇:将静态资源打包为WebJars

SpringBoot2.x基础篇:将静态资源打包为WebJars

作者头像
恒宇少年
发布于 2020-04-24 02:33:16
发布于 2020-04-24 02:33:16
69000
代码可运行
举报
运行总次数:0
代码可运行

知识改变命运,撸码使我快乐,2020继续游走在开源界 点赞再看,养成习惯 给我来个Star吧,点击了解下基于SpringBoot的组件化接口服务落地解决方案

概述

我们在编写前后分离项目时,前端的项目一般需要静态资源(ImageCSSJavaScript...)来进行渲染界面,而如果我们对外采用依赖的方式提供使用时,我们的静态资源文件也应该放入打包文件内,这样才能更便捷的提供我们的功能,在我的开源分布式日志框架 minbox-logging 内提供了管理界面的功能,就是采用的这种方式实现,将静态资源以及编译后HTML页面存放到minbox-logging-admin-ui依赖内,下面我们来看下具体的实现方式。

推荐阅读

了解Resources Static Locations

在我们打包静态资源前,首先来了解下SpringBoot提供的spring.resources.static-locations配置默认值,该配置用于配置ResourceHandler,项目启动后会将该参数的配置值列表作为直接可访问的静态目录进行映射,通过这种方式我们就可以直接访问到我们需要的静态资源内容。

spring.resources.static-locations配置位于org.springframework.boot.autoconfigure.web.ResourceProperties配置类内,其默认值是使用本类内的静态常量CLASSPATH_RESOURCE_LOCATIONS的值,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
private static final String[] CLASSPATH_RESOURCE_LOCATIONS = { "classpath:/META-INF/resources/",
                                                              "classpath:/resources/", "classpath:/static/", "classpath:/public/" };

/**
     * Locations of static resources. Defaults to classpath:[/META-INF/resources/,
     * /resources/, /static/, /public/].
     */
private String[] staticLocations = CLASSPATH_RESOURCE_LOCATIONS;

通过查看源码我们得知,classpath:/META-INF/resources/目录下的资源是可以直接通过默认的映射绑定关系访问到的,通过这一点,我们可以将静态资源依赖内的资源文件存放到META-INF/resources目录下。

资源打包

我们使用Maven方式构建一个普通的项目,在pom.xml文件内添加资源目录配置,在编译过程中将src/main/resources目录下的文件全部复制到META-INF/resources下,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<build>
  <resources>
    <resource>
      <directory>src/main/resources</directory>
      <targetPath>META-INF/resources</targetPath>
    </resource>
  </resources>
</build>

为了验证资源访问,我们在src/main/resources目录下存放一个名为head.jpg的图片。

我们为了本地演示使用,将Maven项目通过mvn install命令安装到本地仓库,以便于提供给其他项目使用。

使用WebJars依赖

我们来创建一个SpringBoot项目,在项目的pom.xml文件内添加如下依赖:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependencies>
  <!--静态资源的访问映射绑定需要web依赖-->
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
  </dependency>
  <dependency>
    <groupId>org.example</groupId>
    <artifactId>webjars-sample</artifactId>
    <version>1.0-SNAPSHOT</version>
  </dependency>
</dependencies>

由于我们在之前通过mvn install命令将静态资源项目安装到了本地仓库,所以我们可以使用依赖。

通过IDEA工具我们可以查看webjars-sample依赖内的资源文件,如下图所示:

image

由于SpringBoot提供的spring.resources.static-locations参数默认值,会将classpath:/META-INF/resources目录作为静态资源映射,所以我们可以直接进行访问head.jpg文件。

运行SpringBoot项目,通过访问 http://localhost:8080/head.jpg,效果如下图:

image

静态资源访问前缀

我们在访问静态资源的时候并没有直接加前缀,而是通过ip:port/head.jpg直接访问,这主要是SpringBoot还提供了另外一个配置spring.mvc.static-path-pattern,其作用是用来配置静态资源的访问前缀,默认值为/**,如果需要修改直接在application.yml文件内进行赋值即可,

application.yml配置文件,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
spring:
  application:
    name: example
  mvc:
    static-path-pattern: /static/**

我们修改了spring.mvc.static-path-pattern配置的值为/static/**,当我们重启项目后需要通过 http://localhost:8080/static/head.jpg 才可以访问到资源。

总结

如果你有一些资源不希望被别人修改,让使用者更加便利的集成时,可以采用这种方式来封装自己的webjars,只需要添加依赖引用就可以访问到静态资源,也可以将静态HTML网页通过这种方式打包。

作者个人 博客 使用开源框架 ApiBoot 助你成为Api接口服务架构师

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Spring Boot 静态资源处理
Spring Boot 默认为我们提供了静态资源处理,使用 WebMvcAutoConfiguration 中的配置各种属性。
全栈程序员站长
2022/08/24
9260
Spring Boot 静态资源处理
Spring MVC和springboot静态资源处理详细总结
优雅REST风格的资源URL不希望带 .html 或 .do 等后缀.由于早期的Spring MVC不能很好地处理静态资源,所以在web.xml中配置DispatcherServlet的请求映射,往往使用 *.do 、 * .xhtml等方式。这就决定了请求URL必须是一个带后缀的URL,而无法采用真正的REST风格的URL
大忽悠爱学习
2021/11/15
2.7K0
SpringBoot2---静态资源映射规则
当前项目 + static-path-pattern + 静态资源名 = 静态资源文件夹下找
大忽悠爱学习
2021/11/15
1.3K0
(四) SpringBoot起飞之路-Web静态资源处理
这是第四篇,关于如何处理第三方静态资源以及自己的静态资源的小结,其实如果仅仅想要知道将静态资源放在哪里,或者说怎么直接用,其实几句话就说完了,但是我在文中是循着源码或者官网/Github,诱导到这几个点,虽然算不得什么源码分析,不过起码静态资源处理的有关问题,起码不算空口而说,算是简单的引导吧
BWH_Steven
2020/05/20
1.1K1
【WEB系列】静态资源配置与读取
SpringWeb项目除了我们常见的返回json串之外,还可以直接返回静态资源(当然在现如今前后端分离比较普遍的情况下,不太常见了),一些简单的web项目中,前后端可能就一个人包圆了,前端页面,js/css文件也都直接放在Spring项目中,那么你知道这些静态资源文件放哪里么
一灰灰blog
2020/06/13
1.3K0
从SpringBoot源码看资源映射原理
很多的小伙伴刚刚接触SpringBoot的时候,可能会遇到加载不到静态资源的情况。
HUC思梦
2022/05/11
5450
从SpringBoot源码看资源映射原理
写在前面:2020年面试必备的Java后端进阶面试题总结了一份复习指南在Github上,内容详细,图文并茂,有需要学习的朋友可以Star一下! GitHub地址:https://github.com/abel-max/Java-Study-Note/tree/master
用户5546570
2020/09/28
8180
Springboot中如何访问静态资源
这个配置项是告诉springboot,应该以什么样的方式去寻找资源。默认配置为 /* 。换句话说,只有静态资源满足什么样的匹配条件,Spring Boot才会处理静态资源请求 比如下面这个配置
凯哥Java
2019/06/28
4.1K0
Springboot中如何访问静态资源
8.8 Spring Boot静态资源处理小结
当使用Spring Boot来开发一个完整的系统时,我们往往需要用到前端页面,这就不可或缺地需要访问到静态资源,比如图片、css、js等文件。
一个会写诗的程序员
2018/08/20
1.1K0
SpringBoot中jsp里面的静态资源js、css、images访问不到解决办法
参考:https://www.cnblogs.com/zfding/p/11766062.html
别先生
2020/10/10
5K0
SpringBoot中jsp里面的静态资源js、css、images访问不到解决办法
SpringBoot【静态资源】
  SpringBoot中的静态资源的存放路径和我们前面的web项目还是有些区别的,本文我们来介绍下SpringBoot中的静态资源。   springboot访问静态资源,默认有两个默认目录,
用户4919348
2019/05/15
1.1K0
看完这篇SpringBoot访问静态资源,我感觉我又会了!!!
  根据多年开发的经历,发现与前端交互的后端项目,静态资源服务是必不可少的(例如图片,文件),大型项目可能是有独立的oss对象存储文件服务器,小型项目基本是存储在本地磁盘通过后端服务访问到静态资源(图片,文件),本章内容就是讲解如何通过后端服务访问到静态资源。
main方法
2020/12/07
10K0
看完这篇SpringBoot访问静态资源,我感觉我又会了!!!
springboot 资源resource文件加载优先级
在通过spring项目官网生成的springboot project项目中,通常我们知道,resource目录是存放项目的静态资源的目录,如在很久以前,项目开发没有采用前后端分离的时候,那么大量的js文件和html都将放到resource目录。 但是我们可以看到,这个自动生成的目录中有个static目录:
冬天里的懒猫
2021/03/04
1.1K0
SpringBoot开发案例之配置静态资源文件路径
SpringBoot本质上是为微服务而生的,以JAR的形式启动运行,但是有时候静态资源的访问是必不可少的,比如:image、js、css 等资源的访问。
小柒2012
2018/03/30
2.5K2
SpringBoot开发案例之配置静态资源文件路径
SpringBoot之静态资源的访问与管理
只要静态资源放在类路径下,如项目中:在原本resources目录下面的/static目录在我们创建的springboot项目就有,或者是我们自己在resources下面创建的/public目录,或者是在原本的resources目录下自己自己创建的/resources目录,又或者是在原本resources目录下自己创建的/META-INF/resources目录。这些目录都是静态资源目录。
害恶细君
2022/11/22
1.1K0
SpringBoot之静态资源的访问与管理
SpringBoot——Web开发(静态资源映射)
SpringBoot对于SpringMVC的自动化配置都在WebMVCAutoConfiguration类中。
Noneplus
2019/09/24
5770
SpringBoot——Web开发(静态资源映射)
Spring Boot +Freemarker开发时候js css等静态资源引入
在我们开发Web应用的时候,会用到大量的js、css、image、html等静态资源资源。
凯哥Java
2019/06/28
3.8K0
深入Spring Boot (七):静态资源使用详解
Web应用经常需要使用大量的静态资源,如图片、css、js等,Spring Boot对这些静态资源的使用提供了默认配置。本篇将详细介绍如何使用默认配置和如何修改这些默认配置,主要包含以下5部分内容: 1.静态资源存储路径; 2.静态资源访问路径; 3.最佳实践; 4.应用欢迎页; 5.应用图标。 1.静态资源存储路径 默认配置下,使用Spring Boot可以将静态资源存储在/static或/public或/resources或/META-INF/resources目录下,这四个目录的根目录都是classp
JavaQ
2018/04/08
3K0
深入Spring Boot (七):静态资源使用详解
SpringBoot 静态资源怎么整的,终于彻底会了
先找到这个类:WebMvcAutoConfiguration,在这个jar包里面,还是自动配置
剽悍一小兔
2021/07/08
7410
SpringBoot-05 Web开发
首先查看WebMvcAutoConfiguration.class(可以直接全局查找)
张小驰出没
2021/04/15
3480
SpringBoot-05  Web开发
相关推荐
Spring Boot 静态资源处理
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验