共计 3392 个字符,预计需要花费 9 分钟才能阅读完成。
导读 | 今天带大家分析 java 拦截器和过滤器的区别, 文中有非常详细的解释说明, 对正在学习 java 的小伙伴们有很好的帮助, 需要的朋友可以参考下 |
过滤器处于客户端与 Web 资源(Servlet、JSP、HTML)之间,客户端与 Web 资源之间的请求和响应都要通过过滤器进行过滤。举例:在过滤器中定义了禁止访问 192.10.10.1 这个地址,那么当客户端发出访问 192.10.10.1 的请求时,经过过滤器后,客户端得到的响应是出现该 IP 禁止访问的提示。在 java web 中,你传入的 request,response 提前过滤掉一些信息,或者提前设置一些参数,然后再传入 servlet 或者 struts 的 action 进行业务逻辑,比如过滤掉非法 url(不是 login.do 的地址请求,如果用户没有登陆都过滤掉), 或者在传入 servlet 或者 struts 的 action 前统一设置字符集,或者去除掉一些非法字符
拦截器是一种面向方面 / 切面编程(AOP Aspect-Oriented Programming),而面向切面就是将多个模块的通用服务进行分离,如权限管理、日志服务,他们在多个模块中都会用到,就可以将其各自封装为一个可重用模块。而这些通用服务的具体实现是通过拦截器来完成,比如用户客户端访问一些保密模块都应先通过权限审查的拦截器来进行权限审查,确定用户是否具有该项操作的权限后方能向下执行。在面向切面编程的就是在你的 service 或者一个方法前调用一个方法,或者在方法后调用一个方法,比如动态代理就是拦截器的简单实现,在你调用方法前打印出字符串(或者做其它业务逻辑的操作),也可以在你调用方法后打印出字符串,甚至在你抛出异常的时候做业务逻辑的操作。
1、拦截器是基于 java 的反射机制的,而过滤器是基于函数回调(职责链)
2、过滤器依赖与 servlet 容器,而拦截器不依赖与 servlet 容器
3、拦截器只能对 action 请求起作用,而过滤器则可以对几乎所有的请求起作用
4、拦截器可以访问 action 上下文、值栈里的对象,而过滤器不能
5、在 action 的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次
执行顺序 :过滤前 – 拦截前 – Action 处理 – 拦截后 – 过滤后。个人认为过滤是一个横向的过程,首先把客户端提交的内容进行过滤 (例如未登录用户不能访问内部页面的处理);过滤通过后,拦截器将检查用户提交数据的验证,做一些前期的数据处理,接着把处理后的数据发给对应的 Action;Action 处理完成返回后,拦截器还可以做其他过程 (还没想到要做啥),再向上返回到过滤器的后续操作。
拦截器 :是在面向切面编程的就是在你的 service 或者一个方法前调用一个方法,或者在方法后调用一个方法比如动态代理就是拦截器的简单实现,在你调用方法前打印出字符串(或者做其它业务逻辑的操作),也可以在你调用方法后打印出字符串,甚至在你抛出异常的时候做业务逻辑的操作。
下面通过实例来看一下过滤器和拦截器的区别:
使用拦截器进行 /admin 目录下 jsp 页面的过滤
下面是我实现的 Interceptor class:
package com.test.news.util;
import java.util.Map;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import com.test.news.action.AdminLoginAction;
/**
* @author chaoyin
*/
public class AccessInterceptor extends AbstractInterceptor {
private static final long serialVersionUID = -4291195782860785705L;
@Override
public String intercept(ActionInvocation actionInvocation) throws Exception {ActionContext actionContext = actionInvocation.getInvocationContext();
Map session = actionContext.getSession();
//except login action
Object action = actionInvocation.getAction();
if (action instanceof AdminLoginAction) {return actionInvocation.invoke();
}
//check session
if(session.get("user")==null ){return "logout";}
return actionInvocation.invoke();//go on}
}
过滤器 :是在 java web 中,你传入的 request,response 提前过滤掉一些信息,或者提前设置一些参数,然后再传入 servlet 或者 struts 的 action 进行业务逻辑,比如过滤掉非法 url(不是 login.do 的地址请求,如果用户没有登陆都过滤掉), 或者在传入 servlet 或者 struts 的 action 前统一设置字符集,或者去除掉一些非法字符.
使用过滤器进行 /admin 目录下 jsp 页面的过滤,首先在 web.xml 进行过滤器配置:
下面是过滤的实现类:
package com.test.news.util;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class AccessFilter implements Filter {
/**
* @author chaoyin
*/
public void destroy() {}
public void doFilter(ServletRequest arg0, ServletResponse arg1,
FilterChain filterChain) throws IOException, ServletException {HttpServletRequest request = (HttpServletRequest)arg0;
HttpServletResponse response = (HttpServletResponse)arg1;
HttpSession session = request.getSession();
if(session.getAttribute("user")== null && request.getRequestURI().indexOf("login.jsp") ==-1 ){response.sendRedirect("login.jsp");
return ;
}
filterChain.doFilter(arg0, arg1);
}
public void init(FilterConfig arg0) throws ServletException {}}
到此这篇关于 Java 拦截器和过滤器的区别分析的文章就介绍到这了