过滤器,是在java web中,你传入的request,response提早过滤掉一些信息,或者提早设置一些参数,而后再传入servlet或者struts的 action进行业务逻辑,好比过滤掉非法url(不是login.do的地址请求,若是用户没有登录都过滤掉),或者在传入servlet或者 struts的action前统一设置字符集,或者去除掉一些非法字符. java
拦截器,是在面向切面编程的就是在你的service或者一个方法,前调用一个方法,或者在方法后调用一个方法好比动态代理就是拦截器的简单实现,在你调用方法前打印出字符串(或者作其它业务逻辑的操做),也能够在你调用方法后打印出字符串,甚至在你抛出异常的时候作业务逻辑的操做。 web
拦截器与过滤器的区别: 编程
执行顺序:过滤前 - 拦截前 - Action处理 - 拦截后 - 过滤后。我的认为过滤是一个横向的过程,首先把客户端提交的内容进行过滤(例如未登陆用户不能访问内部页面的处理);过滤经过后,拦截器将检查用户提交数据的验证,作一些前期的数据处理,接着把处理后的数据发给对应的Action;Action处理完成返回后,拦截器还能够作其余过程(还没想到要作啥),再向上返回到过滤器的后续操做。 函数