![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=1738898287-kMsFbsB1FPOc1ATobCu5xCqGhyugpYjX-0-5c78aa90e6b3da8055e153ef1637c92a)
如以上源码所示,静态资源的映射是在addResourceHandlers()方法中进行映射配置的,它类似于在Spring MVC配置文件中的如下配置代码:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/139-2.jpg?sign=1738898287-yqjMtzF23lFBHN3BGYOYmCMfmqQlUZCr-0-bc93ba776acc2ff6c6628af06fcd2adb)
回到addResourceHandlers()源码中来,staticPathPattern的变量值为"/**",其默认值在WebMvcProperties类中。实际的静态资源存放目录通过getResourceLocations()方法获取,该方法源码如下所示:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/139-3.jpg?sign=1738898287-e1cl0FTisMesPvmVOW44kylYTPlBgUeH-0-95bf528bb7467ac74a9f8b614883f71d)
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/140-1.jpg?sign=1738898287-5dEjRNdMeky7XGrPAEMjfyh0MEH2XfVL-0-3a7ce58c79ade875a4345bac0175f592)
由此可知,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=1738898287-4B6lJRojxQEk0h4rjqQxwKMroShoWKUg-0-93689ef73ede441dec7473ebe6330cd9)
图7-4 静态资源文件
重启Spring Boot,在启动成功后打开浏览器并输入以下请求地址分别进行请求:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/140-3.jpg?sign=1738898287-zxx75enMzZDsTA9LwJMF7q8E8YUzQgAO-0-2b19fd533c9bd2c6b011558ea2437550)
访问结果如图7-5~7-8所示。
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-1.jpg?sign=1738898287-PuN0tEFLkywxqmphBNZtqEQjWUKcFIEq-0-32b811c6275118d1ac7f456b887ef124)
图7-5 logo.png请求结果
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-2.jpg?sign=1738898287-hOkyqF4f5sCiYjbHYkXvd33GxXLRhtGn-0-47e2c00aac9c5131e7b0f62efbfb8415)
图7-6 main.css请求结果
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-3.jpg?sign=1738898287-hch5aUAWrahEENyNmMPa2rVCwsodtg5g-0-51f501247b6a114c30129c3ff3230297)
图7-7 test.html请求结果
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/141-4.jpg?sign=1738898287-skb60qw6TUUqOJNYTYwk22m8P9l4D8mz-0-cc5a7234f7be82b7e43ca7e9e66b7b58)
图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=1738898287-lzxo5vrOnN3X6U5F7AlXsf5KP1u5fl76-0-807aa0fd00ed5ef8adb787bbdc1c61cf)
在修改后重启Spring Boot项目,再次使用原来的URL访问以上三个资源文件将会报404的错误,如图7-9所示。
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/142-2.jpg?sign=1738898287-VMuIHciAFTBJBw7GfCxiimf5qJ4W0GfW-0-da06b41d32d09aab2be3ff89fb853210)
图7-9 404错误
如果想要正常访问文件,则需要新建static-test目录并将静态资源文件移至file-test目录下,且修改访问路径为:
![](https://epubservercos.yuewen.com/3069E4/20862583308964806/epubprivate/OEBPS/Images/142-3.jpg?sign=1738898287-SZzaNuFAV4qV5ILeJVM8D2Z9csTnij9x-0-36bf9c2ae226a5178b1af6616d98584e)
此时页面就不会出现404错误。