![Spring Boot实战:从0开始动手搭建企业级项目](https://wfqqreader-1252317822.image.myqcloud.com/cover/850/40107850/b_40107850.jpg)
7.6 Spring Boot对静态资源的映射规则
与普通Spring Web项目相比,Spring Boot项目的目录结构中仅有java和resources两个目录。用于存放资源文件的webapp目录在Spring Boot项目的目录结构中根本不存在。那么Spring Boot是如何处理静态资源的呢? WebMVC在自动配置时针对资源文件的访问又做了哪些配置呢?
由源码可知,这部分配置依然是通过WebMvcAutoConfigurationAdapter内部类完成的,源码如下所示:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/138-2.jpg?sign=1738861548-xz4oJ9L4KbvfCwIP906B3ZTG4Y2pmIFa-0-79189ed4be56dac233095c251733e194)
如以上源码所示,静态资源的映射是在addResourceHandlers()方法中进行映射配置的,它类似于在Spring MVC配置文件中的如下配置代码:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/139-2.jpg?sign=1738861548-HxHErcyhAbfOLc6bqKjMhdkz4ijSUGmi-0-6a43c4903d58dc2710a74044703a6662)
回到addResourceHandlers()源码中来,staticPathPattern的变量值为"/**",其默认值在WebMvcProperties类中。实际的静态资源存放目录通过getResourceLocations()方法获取,该方法源码如下所示:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/139-3.jpg?sign=1738861548-eLoQ7bImp01Hbf0yCKXqxk70yVMgEbYc-0-2cba6e0dd3b26a4071c75cd060ab5213)
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/140-1.jpg?sign=1738861548-qpY2K1lMr3fpCNWQxgHgJ4S0NxIKaEbL-0-0e64e76bcc55d0ae24aa29b1f0640a3e)
由此可知,Spring Boot默认的静态资源处理目录为:"classpath:/META-INF/ resources/"、"classpath:/resources/"、"classpath:/static/"、"classpath:/public/"。
由于访问当前项目的任何资源都能在静态资源的文件夹中查找,而不存在的资源则会显示相应的错误页面,因此在开发Web项目时只需要包含这几个目录中的任意一个或者多个,并将静态资源文件放入其中即可。
为了验证该配置,可以在类路径下分别创建public目录(PNG格式文件)、resources目录(CSS格式文件)、stati目录(HTML格式文件和JS格式文件),并分别在三个文件夹中放入静态文件,如图7-4所示。
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/140-2.jpg?sign=1738861548-qdIvBT4uvYJW93K9XsEwIu76JumIsPEo-0-e27c1334e14ca42bf9438b6fd9c44a00)
图7-4 静态资源文件
重启Spring Boot,在启动成功后打开浏览器并输入以下请求地址分别进行请求:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/140-3.jpg?sign=1738861548-SHmEYOeJNAmjjoigo1oqYgIvH9AYzRRc-0-4231b8045bd4c61d2f728fa434a32f46)
访问结果如图7-5~7-8所示。
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-1.jpg?sign=1738861548-nk2eJPpWEMcHybxTgJAkQew2BRS0lvtb-0-e7760be3f9b50f2faeae489d2572bea1)
图7-5 logo.png请求结果
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-2.jpg?sign=1738861548-99XHk6GXhX6dI6kJmbFCP3ODzsAWDu9x-0-c211a90453f88009f9bcee562129d0b7)
图7-6 main.css请求结果
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-3.jpg?sign=1738861548-SHMpefEmSruWswsSxw36B7k9C1h2pYia-0-69553aff619de12b94ef49c7d8101103)
图7-7 test.html请求结果
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-4.jpg?sign=1738861548-dJlL6RI7VOm6ucfo5cSuFKe3jlAsu92n-0-76676d2675d0a6aedab9619b508401ae)
图7-8 test.js请求结果
通过以上请求结果可以发现,静态资源虽然在不同的目录中,但都能被正确返回。这就是Spring Boot对静态资源的拦截处理。
当然,开发时也可以在Spring Boot项目配置文件中修改这些属性。比如将拦截路径改为“/static/”,并将静态资源目录修改为“/file-test”,那么默认配置就会失效并使用开发人员自定义的配置。修改application.properties文件,添加如下配置:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/142-1.jpg?sign=1738861548-1lLIAzQMckGQEUfkiViN5yyrgl9F3OPi-0-1ae7c858e7706bbe6a9792c08afcfc8f)
在修改后重启Spring Boot项目,再次使用原来的URL访问以上三个资源文件将会报404的错误,如图7-9所示。
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/142-2.jpg?sign=1738861548-3cG65G0BETRE8yObdmO9FS4EXhXgOyHu-0-af106597474ce1a358352ee21b42351c)
图7-9 404错误
如果想要正常访问文件,则需要新建static-test目录并将静态资源文件移至file-test目录下,且修改访问路径为:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/142-3.jpg?sign=1738861548-Fd1P9mXsPcfwcjTQUWXfQBSrGl82F5oq-0-7d1bd1433381dff2b987606162c2e379)
此时页面就不会出现404错误。