• Servlet过滤器与监听器


    过滤器

    顾名思义是起到过滤的作用,所有的请求在真正到达servlet之前都会首先经过过滤器过滤一遍。

    过滤器也是Servlet的一种,因此也有init和destroy方法,还有一个服务方法,只是这里提供的服务是过滤;

    一个Servlet要想成为过滤器需要实现javax.servlet.Filter接口;

    一般客户端发出请求后会交给Servlet;如果过滤器存在,则客户端发出的请求都是先交给过滤器,然后交给Servlet;

    我们可以完成一些在执行Servlet之前必须要做的事,比如request.setCharacterEncoding("GBK");

    必须实现以下方法:

    1.public void init(FilterConfig config) throws ServletException{}   //   init方法在Web容器启动时就会调用;
    
    2.public void doFilter(ServletRequest req,ServletResponse resp,FilterChain chain){}  // doFilter的参数是ServletRequest和ServletResponse而不是Http的;
    
    3.public void destroy(){}//应用被关闭时调用

    在实现doFilter方法时一定要执行如下操作:

    public void doFilter(ServletRequest req,ServletResponse resp,FilterChain chain){
    
        chain.doFilter(req,resp);        //向servlet传递请求,否则servlet无法执行
    
    }
    

      

    那么过滤器可以用来干嘛呢?大家可以做两个简单的案例:

    案例1:统一设置字符集

    案例2:拦截URL,不登录不允许直接访问页面

    监听器

    监听器顾名思义就是监听某种事件的发生,即当某个事件发生时,就触发了某个设置好的监听器,但是这里触发的原因不同。

    例如地震监测仪器监听地震的发生,大气监测仪,监测空气的变化以提供预警。

    在servlet中因监听对象的不同也分为不同的监听器,这里指的监听对象是application、session对象,每种对象有各自的监听器。

    1.application监听器:ServletContextListener

    需要实现的方法:

    (1)public void contextInitialized(ServletContextEvent e);       //在application创建时就调用
    
    (2)public void contextDestroyed(ServletContextEvent e);        //当application销毁时调用
    
    ServletContextEvent的getServletContext()方法可以取得application对象;
    

     

    创建完成监听器后需要在web.xml中做如下配置

    <listener>标签是单独出现的

    包含一个子标签,指定了监听类的全称(包名+类名)

    2.application属性监听器:ServletContextAttributeListener

    需要实现的方法:

    (1)public void attributeAdded(ServletContextAttributeEvent e);         
    //当调用application.setAttribute()时调用 (2)public void attributeRemoved(ServletContextAttributeEvent e);
    //当调用applcaition.removeAttribute()时调用 (3)public void attributeReplaced(ServletContextAttributeEvent e);
    //当调用两次application.setAttribute()赋予相同属性时调用

    参数ServletContextAttributeEvent可以获得触发该监听器的属性名称和属性值,方法有:

     

    (1)getName();  取得属性的名称;
    
    (2)getValue();   取得属性的值;(注意:返回的是Object,必须转型)

    3.session监听器:HttpSessionListener

    需要实现的方法:

    (1)public void sessionCreated(HttpSessionEvent e);                //当打开一个浏览器时,就会触发这个方法;
    
    (2)public void sessionDestroyed(HttpSessionEvent e);            //当调用session.invalidate();或超时时调用

    HttpSessionEvent的方法getSession()获得触发监听器的session对象;  

    销毁session常用的有2种方式:

    (1)session.invalidate();//直接销毁

    (2)在web.xml中设置超时时间://所有session起作用

    4.session属性监听器:HttpSessionAttributeListener

    需要实现的方法:

    (1)public void attributeAdded(HttpSessionBindingEvent e);        
    //当调用session.setAttribute()时调用 (2)public void attributeRemoved(HttpSessionBindingEvent e);
    //当调用session.removeAttribute()时调用 (3)public void attributeReplaced(HttpSessionBindingEvent e);
    //当调用两次session.setAttribute()赋予相同属性时调用

      

    HttpSessionBindingEvent 方法:

    (1)getSession();//获取触发监听器的session

    (2)getName();//获取属性名称

    (3)getValue();//获取属性值

    监听器应用场景

    ServletContextListener:在任何Servlet提供服务之前执行、在Servlet销毁时执行,用于提前初始化一些资源,比如数据库连接、销毁一些资源,比如数据库连接;

    ServletContextAttributeListener:上下文中添加、删除、替换了属性;

    HttpSessionListener:多少个在线用户,即跟踪会话;

    HttpSessionAttributeListener:会话属性添加、删除、替换;

     心得:

    今天的成功是因为昨天的积累,明天的成功则依赖于今天的努力。成功需要一个过程。
  • 相关阅读:
    RESTful API规范
    SOAP和RESTful 框架的 简介、对比和区别
    @requestBody 与@requestparam详解
    关于“Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured.”
    post和get、PostMapping、GetMapping和RequestMapping
    强引用、软引用、弱引用、虚引用及方法区的垃圾回收策略
    jvm运行时数据区域
    HBase入门
    各种http报错的报错的状态码的分析
    maven配置多个镜像
  • 原文地址:https://www.cnblogs.com/www-tty-com/p/13660997.html
Copyright © 2020-2023  润新知