java静态资源存储_SpringBoot项目访问静态资源

一、目的说明

先说源码:https://github.com/goldenJet/POIDemo.git

如下是我们的 resources 结构和 controller 实现,目的是通过 http://localhost:8081/home 这个路径来访问我们指定在 templetes 文件夹下的 index.html。

213560e9811a386e72e9df951af5f37f.png      

2e18d0cdf5ad25bab6fc946a475d5a54.png

但是事实是,给我们返回的是 404,很伤心。

f24f71fa03d31a611dfb27f217b7a9fb.png

二、方法一:使用模板引擎实现

Java 的 web 项目,我们常用一些前端的模板引擎,比如 SpringBoot 已经自支持的 Thymeleaf 和 FreeMaker 等。

比如以 Thymeleaf 为例,我们需要引入他的包,如下。

org.springframework.boot

spring-boot-starter-thymeleaf

然后修改 controller 中返回的页面名称,@RequestMapping("/home")

public String home(){

return "index";

}

重启项目,然后便能正常访问了,

a2bb461ee371f148888287a71e019076.png

是不是很神奇,其实很简单,就是 Thymeleaf 会根据我们返回的页面名字(此处是“index”),自动去 templates 文件夹下去查找有没有对应的 index.html 模板,然后进行渲染返回给我们,因为默认配置的是去 templates 文件夹下查找 .html 结尾的模板。具体配置参数可见 ThymeleafProperties这个类,下图是部分源码截图,

8aad66a37edca42da334fbbd7638bbef.png

当然,如果想覆盖掉默认的配置,只需要去 application.properties 配置文件中 覆盖掉对应的参数即可,如下:server.port=8081

#>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> thymeleaf 配置

# 推荐配置项

# 缓存关闭(即每次渲染都会去重新请求服务器)

spring.thymeleaf.cache=false

# 随意一点,默认的挺好

# 模板所在位置

spring.thymeleaf.prefix=classpath:/templates/

# 模板后缀

spring.thymeleaf.suffix=.html

# 不解释

spring.thymeleaf.content-type=text/html

spring.thymeleaf.encoding=UTF-8

spring.thymeleaf.mode=HTML5

#<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

三、方法二:改变资源映射来实现

我们把 pom.xml 中的 thymeleaf 的包注掉,然后修改 controller 中的相关代码,直接返回 index.html,显然此时是无法访问的,@Controller

public class Home {

@RequestMapping("/home")

public String home(){

return "index.html";

}

}

怎么办呢,既然它找不到我们的文件路劲,那么我们就给他指条明路不就好了,

所以我们指定资源的映射,写一个配置类不就OK了,这个类需要继承 WebMvcConfigurerAdapter,然后复写其中的 addResourceHandlers 方法就好,如下例:@Configuration

public class MvcConfigurer extends WebMvcConfigurerAdapter {

/**

* 配置静态资源访问

* @param registry

*/

@Override

public void addResourceHandlers(ResourceHandlerRegistry registry) {

// 将资源路径映射到指定的classpath

registry.addResourceHandler("/**").addResourceLocations("classpath:/templates/");

super.addResourceHandlers(registry);

}

}

此处我们是将所有的访问路径,即“/**”映射到 templates 文件夹下,你也可以根据自己的需求来具体配置,

当然,资源路径还可以映射到本地,即映射到 D 盘之类的,如下:// 将资源路径映射到计算机本地 D 盘

registry.addResourceHandler("/d/**").addResourceLocations("file:D:/");

四、进阶小篇(优先级的问题)

其实,一个 web 项目,在classpath 目录下,一般会有以下几个常用的目录,

我们在里面都放了一个 index.html,body里面就一个p 标签,如下:

4807d430f218ebaa6806d9008c6d9507.png

好,亮点来了,我们把资源路径的映射注掉,然后重启项目,仍旧访问 http://localhost:8081/home

7ba9cfa16d4464ffb4fd92d045ceb0f3.png

嘿嘿,之前不能访问的,现在却能访问?其实玄机就是 web 项目,默认的 classpath 下的路径便是 classpath:/META-INF/resources/

当然,你再把这个目录下的 index.html 删掉,访问,

9fe7f3a36687ed9e6dfe037d8aab5078.png

好吧,他还是找到了 resources 目录下,继续删,

b75c0bfb2df09275286a72132e7449d1.png

好吧,他还会继续找到 static 目录下,继续删,

6a5286d1d57cdeb55b3536ead5edc0b7.png

OK,接着会找到 public,再删,好吧,然后就 404 了,

所以,总结,这四个目录是默认的存储静态资源的路径,当然了,他们也是存在优先级的,如下,从左到右优先级依次降低:

/META-INF/resources >> /resources >> /static >> /public

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值