当我们搭建SSM项目的时候,我们发现,跟前端页面相关的一些静态资源不能访问到,导致出现下图的形式:
这是因为我们现在在服务器上配置的主要处理Servlet的前端处理器是DispatcherServlet这个SpringMVC的处理器,servlet的url-pattern为“\”表示拦截所有请求,这样会导致我们的静态资源如图片,js,css等静态资源无法被访问,在 SSM 中设立起拦截器之后,很多静态的资源在加载的时候是会被拦截下来的,它不能完成静态资源的访问处理,所以⻚⾯中的相关静态资源的引⽤是⽆法实现的,所以要想办法解决静态资源的处理⽅式,有以下三种方法:
1.引⼊Tomcat的默认处理Servlet(DefaultServlet),使⽤该Servlet来完成静态资源的处理。在web.xml中添加以下的配置信息:
<!-- 引⼊Tomcat的默认Servlet来处理静态资源 -->
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.jpg</url-pattern>
<url-pattern>*.css</url-pattern>
<url-pattern>*.png</url-pattern>
<url-pattern>*.gif</url-pattern>
<url-pattern>*.js</url-pattern>
</servlet-mapping>
2.处理静态资源的⽅式,将原来的DispatcherServlet的处理映射请求修改为*.action样式
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>*.action</url-pattern>
</servlet-mapping>
3.使⽤SpringMVC中的静态资源的映射设置这⾥需要在SpringMVC-servlet.xml中进⾏配置如下的内容:
<mvc:resources mapping=“client/js/**” location=“client/js/”/>
这其中包含两具属性分别是:
mapping–是指访问映射的路径,就是jsp⻚⾯中引⼊该静态资源的超链接,href,src。
location–是指定要访问的静态资源在服务器中的相对位置
SpringMVC-servlet.xml:注意里面的路径一定要跟你自己的路径相对应
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 启⽤注解的⽅式 -->
<context:annotation-config />
<!-- 使⽤包扫描的⽅式 -->
<context:component-scan base-package="com.lz.xbmu" />
<!-- 配置视图解析器 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 前缀 -->
<property name="prefix" value="/WEB-INF/jsp/"></property>
<!-- 后缀 -->
<property name="suffix" value=".jsp"></property>
</bean>
<!-- mvc的注解驱动 -->
<mvc:annotation-driven />
<!-- 配置静态资源的访问路径 -->
<mvc:resources mapping="client/js/**" location="client/js/" />
<mvc:resources mapping="client/ad/**" location="client/ad/" />
<mvc:resources mapping="client/bookcover/**" location="client/bookcover/" />
<mvc:resources mapping="client/css/**" location="client/css/" />
<mvc:resources mapping="client/images/**" location="client/images/" />
</beans>
以上三种⽅式都可以解决静态资源的访问问题,但是了各有各⾃的优缺点。使⽤时要全⾯考滤。