java WEB开发:过滤器、监听器、拦截器的区别

1.过滤器

Servlet中的过滤器Filter是实现了javax.servlet.Filter接口的服务器端程序,主要
的用途是过滤字符编码、做一些业务逻辑判断等。其工作原理是,只要你在web.xml文
件配置好要拦截的客户端请求,它都会帮你拦截到请求,此时你就可以对请求或响应
(Request、Response)统一设置编码,简化操作;同时还可进行逻辑判断,如用户是
否已经登陆、有没有权限访问该页面等等工作。它是随你的web应用启动而启动的,只
初始化一次,以后就可以拦截相关请求,只有当你的web应用停止或重新部署的时候才
销毁,

2.监听器

现在来说说Servlet的监听器Listener,它是实现
了javax.servlet.ServletContextListener 接口的服务器端程序,它也是随web应用
的启动而启动,只初始化一次,随web应用的停止而销毁。主要作用是: 做一些初始
化的内容添加工作、设置一些基本的内容、比如一些参数或者是一些固定的对象等等。

3.拦截器

拦截器是在面向切面编程中应用的,就是在你的service或者一个方法前调用一个方
法,或者在方法后调用一个方法。是基于JAVA的反射机制。拦截器不是在web.xml,
比如struts在struts.xml中配置,

 

Filter基于回调函数,我们需要实现的filter接口中doFilter方法就是回调函数,而
interceptor则基于java本身的反射机制,这是两者最本质的区别。
Filter是依赖于servlet容器的,即只能在servlet容器中执行,很显然没有servlet容
器就无法来回调doFilter方法。而interceptor与servlet容器无关。
Filter的过滤范围比Interceptor大,Filter除了过滤请求外通过通配符可以保护页
面,图片,文件等等,而Interceptor只能过滤请求。
Filter的过滤例外一般是在加载的时候在init方法声明,而Interceptor可以通过
在xml声明是guest请求还是user请求来辨别是否过滤

 

====================================================================

1、拦截器是基于java的反射机制的,而过滤器是基于函数回调。
2、过滤器依赖于servlet容器,而拦截器不依赖于servlet容器。
3、拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
4、在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用
一次

    拦截器:
就是在你调用一个方法前,或者调用一个方法后,做一些业务逻辑的操作,例如打
印字符串。

    下面通过实例来看一下过滤器和拦截器的区别:
<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


使用拦截器进行/admin 目录下jsp页面的过滤:

<package name="newsDemo" extends="struts-default" namespace="/admin">
        <interceptors>
            <interceptor name="auth" class="com.test.news.util.AccessInterceptor" />
            <interceptor-stack name="authStack">
                <interceptor-ref name="auth" />
            </interceptor-stack>
        </interceptors>
        <!-- action -->
        <action name="newsAdminView!*" class="newsAction" method="{1}">
           </interceptor-ref>

<interceptor-ref name="defaultStack"/>
            <interceptor-ref name="authStack">
           </interceptor-ref>

</action>

</package>

下面是我实现的拦截器:


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;

public class AccessInterceptor extends AbstractInterceptor {

    private static final long serialVersionUID = -4291195782860785705L;

    public String intercept(ActionInvocation actionInvocation) throws Exception {
         ActionContext actionContext = actionInvocation.getInvocationContext();
         Map session = actionContext.getSession();
   
         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
     }
}
      

过滤器:就是在你访问某个JSP、Servlet或者Action之前,过滤掉一些信息。


使用过滤器进行/admin 目录下jsp页面的过滤,首先在web.xml进行过滤

器配置:

 

<filter>
        <filter-name>access filter</filter-name>
        <filter-class>
             com.test.news.util.AccessFilter
        </filter-class>
    </filter>
    <filter-mapping>
        <filter-name>access filter</filter-name>
        <url-pattern>/admin</url-pattern>

  </filter-mapping>

转载自:http://yunjkj.com/javajc/2892.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值