方案三 ,使用
Xml代码
1.
会把\注册到SimpleUrlHandlerMapping的urlMap中,把对静态资源的访问由HandlerMapping转到
org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler处理并返回. DefaultServletHttpRequestHandler使用就是各个Servlet容器自己的默认Servlet.
补充说明:多个HandlerMapping的执行顺序问题: DefaultAnnotationHandlerMapping的order属性值是:0
是: 2147483646
spring会先执行order值比较小的。当访问一个a.jpg图片文件时,先通过
DefaultAnnotationHandlerMapping 来找处理器,一定是找不到的,因为我们没有叫a.jpg的Action。然后再按order值升序找,由于最后一个 SimpleUrlHandlerMapping 是匹配 \的,所以一定会匹配上,就可以响应图片。
访问一个图片,还要走层层匹配。不知性能如何?
最后再说明一下,方案二、方案三 在访问静态资源时,如果有匹配的(近似)总拦截器,就会走拦截器。如果你在拦截中实现权限检查,要注意过滤这些对静态文件的请求。 如何你的DispatcherServlet拦截 *.do这样的URL后缀,就不存上述问题了。还是有后缀方便。
转载请注明出处:原文地址:http://elf8848.iteye.com/blog/875830
八、请求如何映射到具体的Action中的方法?
方案一:基于xml配置映射,可以利用SimpleUrlHandlerMapping、BeanNameUrlHandlerMapping进行Url映射和拦截请求。 配置方法略。
方案二:基于注解映射,可以使用DefaultAnnotationHandlerMapping。
Xml代码
1. DefaultAnnotationHandlerMapping\>
但前面我们配置了
如何替换
以上都可以注入interceptors,实现权限控制等前置工作。 我们使用第2种,基于注解来使用spring MVC
并在action类上使用:
@Controller
@RequestMapping(\
转载请注明出处:原文地址:http://elf8848.iteye.com/blog/875830
九、Spring中的拦截器:
Spring为我们提供了:
org.springframework.web.servlet.HandlerInterceptor接口,
org.springframework.web.servlet.handler.HandlerInterceptorAdapter适配器, 实现这个接口或继承此类,可以非常方便的实现自己的拦截器。
有以下三个方法:
Action之前执行:
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler);
生成视图之前执行
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView);
最后执行,可用于释放资源
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
分别实现预处理、后处理(调用了Service并返回ModelAndView,但未进行页面渲染)、返回处理(已经渲染了页面)
在preHandle中,可以进行编码、安全控制等处理; 在postHandle中,有机会修改ModelAndView;
在afterCompletion中,可以根据ex是否为null判断是否发生了异常,进行日志记录。
参数中的Object handler是下一个拦截器。
转载请注明出处:原文地址:http://elf8848.iteye.com/blog/875830
十、如何使用拦截器?
自定义一个拦截器,要实现HandlerInterceptor接口:
Java代码
1. public class MyInteceptor implements HandlerIntercepto
r {
2. 略。。。
3. }
Spring MVC并没有总的拦截器,不能对所有的请求进行前后拦截。 Spring MVC的拦截器,是属于HandlerMapping级别的,可以有多个HandlerMapping ,每个HandlerMapping可以有自己的拦截器。
当一个请求按Order值从小到大,顺序执行HandlerMapping接口的实现类时,哪一个先有返回,那就可以结束了,后面的HandlerMapping就不走了,本道工
序就完成了。就转到下一道工序了。
拦截器会在什么时候执行呢? 一个请求交给一个HandlerMapping时,这个HandlerMapping先找有没有处理器来处理这个请求,如何找到了,就执行拦截器,执行完拦截后,交给目标处理器。
如果没有找到处理器,那么这个拦截器就不会被执行。
在spring MVC的配置文件中配置有三种方法:
方案一,(近似)总拦截器,拦截所有url
Java代码
1.
2.
为什么叫“近似”,前面说了,Spring没有总的拦截器。
如果是REST风格的URL,静态资源也会被拦截。
方案二, (近似) 总拦截器, 拦截匹配的URL。
Xml代码
1. 2. 3. 4. 5. 6.
就是比 方案一多了一个URL匹配。
如果是REST风格的URL,静态资源也会被拦截。
方案三,HandlerMappint上的拦截器。
如果是REST风格的URL,静态资源就不会被拦截。因为我们精准的注入了拦截器。
Xml代码
1. DefaultAnnotationHandlerMapping\> 2. 3. 4. 5. 6. 7.
如果使用了
DefaultAnnotationHandlerMapping 与AnnotationMethodHandlerAdapter 这两个bean,所以就没有机会再给它注入interceptors属性,就无法指定拦截器。 当然我们可以通过人工配置上面的两个Bean,不使用
其实我也不建议使用
如何替换
转载请注明出处:原文地址:http://elf8848.iteye.com/blog/875830
十一、如何实现全局的异常处理?
在spring MVC的配置文件中:
Xml代码
1.
2. servlet.handler.SimpleMappingExceptionResolver\> 3. 6. 9. 10. eMappingExceptionResolver