![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=1738864842-1MBoE2Sk60ZbXJd09uQx9Mul610uJKN8-0-8ed398fd96f6cf2648b5c97b90d433ea)
如以上源码所示,静态资源的映射是在addResourceHandlers()方法中进行映射配置的,它类似于在Spring MVC配置文件中的如下配置代码:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/139-2.jpg?sign=1738864842-PvNwMEbvuyTypJUOetYxRkLN8CHRnhtL-0-9f38eb89c1b4713bc3e161c8841ecb9f)
回到addResourceHandlers()源码中来,staticPathPattern的变量值为"/**",其默认值在WebMvcProperties类中。实际的静态资源存放目录通过getResourceLocations()方法获取,该方法源码如下所示:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/139-3.jpg?sign=1738864842-zJKUHMpQZuMnmQcuIyzFlJLGsRrwLycM-0-59c50f5aea31a7061df9ed902b55ea76)
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/140-1.jpg?sign=1738864842-PatENLg9wCuWmXLjOvwZZwP2z0KZKjBX-0-992ba7328f4bfae9f97be63caa4e90b3)
由此可知,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=1738864842-LOdT7BTU7o2cIi4r6BZ0x9lfTTm8SBuO-0-6765070bc3cecd086024be9c76b9838d)
图7-4 静态资源文件
重启Spring Boot,在启动成功后打开浏览器并输入以下请求地址分别进行请求:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/140-3.jpg?sign=1738864842-ylgrElg2LxacfXhv6MdUsizsTdGscb5v-0-ad7e78a4d767e20e5e68a77e11e6753c)
访问结果如图7-5~7-8所示。
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-1.jpg?sign=1738864842-0e6AQjOoGRU1cnSoGxydzf0r0tR8fJ12-0-8a59516dc67a901eeaee3aba808ee279)
图7-5 logo.png请求结果
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-2.jpg?sign=1738864842-2KthrIXsWnOsRlHNYizHxo8F7iSCt4mY-0-ced59622735f3b9c231a727506873216)
图7-6 main.css请求结果
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-3.jpg?sign=1738864842-VvtOl8Ji1F9FyfNOvqEYmajZw76W3oLE-0-7327051a676f81ddf7d160d964b5472e)
图7-7 test.html请求结果
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-4.jpg?sign=1738864842-y7FxsINgUXrLSuqCrqD82UZqhVMAxr7h-0-841e832b91549f3db6a1d0f60bb395c6)
图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=1738864842-7ROLEr6OOY5zTTbuDR9wp0cOSHSBDG6E-0-73f08cf3c2f77d22553a7d46ec90a123)
在修改后重启Spring Boot项目,再次使用原来的URL访问以上三个资源文件将会报404的错误,如图7-9所示。
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/142-2.jpg?sign=1738864842-pmqsyJivVCgXrwzL8Yc9Xz8T0eTC4lXU-0-a848bdbdf5c93bcd64a65890782595a7)
图7-9 404错误
如果想要正常访问文件,则需要新建static-test目录并将静态资源文件移至file-test目录下,且修改访问路径为:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/142-3.jpg?sign=1738864842-2lzrtaX5JhpyNPIMN0Hta5d0azmnPV92-0-abd2535befb6226520f52da827394b0f)
此时页面就不会出现404错误。