Spring拦截器
程序员文章站
2022-07-09 18:10:31
...
1、什么是拦截器?
通过统一拦截从浏览器发往服务器的请求来完成功能的增强。
2、拦截器使用场景:
解决请求的共性问题(如:乱码问题、权限验证问题等)。
3、拦截器需要实现HandlerInterceptor接口,其中有三个方法:
public class test implements HandlerInterceptor{
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
return false;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
}
}
其中,preHandle方法中的返回值如果为true,请求会继续运行;如果为false,则请求被终止;Object参数表示被拦截的请求目标对象;
postHandle中可以通过ModelAndView,改变显示视图,或改变发往视图的方法;
afterHandle主要用于资源释放;
4、拦截器注册
<mvc:interceptors>
<bean class="org.seckill.dao.testInterceptor"></bean>
</mvc:interceptors>
5、多拦截器应用
6、其他实现拦截器方式
实现WebRequestInterceptor,区别主要在于:preHandle没有返回值,不能终止请求
7、拦截器使用场景:解决请求中的共性问题
例如:乱码问题 、权限验证问题等
8、过滤器与拦截器的区别:
①拦截器是基于java的反射机制的,而过滤器是基于函数回调。
②拦截器不依赖与servlet容器,过滤器依赖与servlet容器。
③拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
④拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
⑤在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
⑥拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑
上一篇: php设计模式-策略模式