A New Start

SpringBoot项目访问静态资源

一、目的说明

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

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

      

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

html03.png

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

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

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

然后修改 controller 中返回的页面名称,

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

html04.png

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

html05.png

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

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

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

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

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

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

然后访问 http://localhost:8081/home 又能愉快地玩耍了。

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

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

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

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

html06.png

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

html07.png

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

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

html10.png

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

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

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

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

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

点赞

发表评论

电子邮件地址不会被公开。 必填项已用*标注