过滤器和拦截器的区别
过滤器
- servlet规范中的一部分,任何用servlet的工程都可以使用
- 拦截web资源,如禁止访问地址,禁止访问图片等
- 对request,response进行一些设置或过滤,如过滤非法字符,非法url
- 全局设置,或者根据url设置
拦截器
- springmvc的一部分,只有使用了springmvc才可以使用
- 只拦截访问的控制器方法,多用于权限管理、日志服务。(因为它只能针对控制器方法做出逻辑,无法控制静态资源),不同方法可以有不同逻辑
核心区别:拦截器是AOP思想的具体应用
实际上过滤器能做的拦截器也能做,一般过滤器只是用来过滤url资源和设置编码,过滤器更多像从多个Servlet的service()方法里抽取的通用代码,通过使用Filter可以实现更好的复用
自定义拦截器
1.实现HandlerInterceptor接口
2.重写接口方法
3.配置xml文件
public class MyInterceptor implements HandlerInterceptor {
/*
在请求处理的方法之前执行
如果返回true就执行下一个拦截器
如果返回false就不执行下一个拦截器,也就终止执行了
*/
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("======"+"处理前"+"==========");
return true;
}
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("======处理后============");
}
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("=============清理==============");
}
}
<mvc:interceptors>
<!-- 使用 bean 定义一个 Interceptor,直接定义在 mvc:interceptors 下面的 Interceptor 将拦截所有的请求 -->
<mvc:interceptor>
<!-- 定义在 mvc:interceptor 下面的 Interceptor,表示对特定的请求进行拦截 -->
<mvc:mapping path="/hello"/>
<bean class="com.hjc.interceptor.MyInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
接口方法
preHandle
进行一些前置初始化操作或者是对当前请求做一个预处理,也可以在这个方法中进行一些判断来决定请求是否要继续进行下去。当它返回为false
时,表示请求中断。
postHandle
在控制器中的方法调用之后执行,但是它会在DispatcherServlet进行视图返回渲染之前被调用,所以我们可以在这个方法中对控制器处理之后的ModelAndView对象进行操作。postHandle方法被调用的方向跟preHandle是相反的,也就是说,先声明的Interceptor的postHandle方法反而会后执行。
afterCompletion
该方法将在整个请求结束之后,也就是在DispatcherServlet
渲染了对应的视图之后执行,这个方法的主要作用是用于进行资源清理的工作。
用户登录页面
即用户本身的首页必须要进行登录,若用户未登录进入首页则会跳转到用户登录页面。该逻辑就可以使用拦截器实现
总结
拦截器是AOP思想的运用,实际上业务逻辑也可以用控制器实现,只是它可以作为控制器的扩展,不需要修改控制器的代码可以添加新的功能,这点的理解比较重要