最近,在弄一个登录系统,使用Spring MVC 整合Shiro进行认证及访问权限管理。遇到了浏览器加载不到静态资源及在JSP页面Ctrl+鼠标左键链接不到图片及CSS样式的问题。根据网上的介绍知道是Spring MVC拦截了静态资源,于是按照网上内容更改了配置。
主要有三种更改方式:
一、在web.xml文件增加配置
在web.xml文件中,Spring MVC的DispatcherServlet配置之前,增加如下配置:
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.js</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.png</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.jpg</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.jpeg</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.css</url-pattern>
</servlet-mapping>
意思就是不过滤这些路径。
二、在Spring MVC的配置文件中增加一行配置:
<mvc:default-servlet-handler/>
三、在Spring MVC的配置文件中增加对静态资源的访问:
<mvc:annotation-driven/>
<mvc:resources mapping="/**" location="/public/images/" />
<mvc:resources mapping="/**" location="/js/" />
<mvc:resources mapping="/**" location="/public/css/"/>
注意:以上三种配置能在没有其他过滤器的情况下解决加载不到静态资源的问题。但是,我整合了Shiro进行权限认证管理,它也会对路径进行拦截,导致还是加载不了静态资源。
解决方法就是在Shiro的拦截路径上也过滤掉访问静态资源的路径。
我的JSP及js、图片资源目录如下:
shiro.xml配置:
<property name="filterChainDefinitions">
<value>
/test=anon
/logout = anon
/ui/checkLogin = anon
<!-- 过滤静态资源 如js、css、图片-->
/public/**=anon
/js/**=anon
/*.ico=anon
/webjars/**=anon
/** = authc,user
</value>
</property>
这样配置之后,我项目里的拦截器均过滤掉了访问静态资源的路径,这样浏览器及jsp均可以加载到静态资源了。