java web 监听器 例子_JavaWeb开发06——监听器和过滤器

过滤器和监听器

一.过滤器1.概述

过滤器运行在服务器端,对服务器端web资源的访问 进行拦截,起到过滤的作用。Servlet API中 定义接口 Filter,用户只需要编写程序实现Filter接口,完成过滤器编写。语法格式:

1、编写类 实现 Filter接口

2、在服务器端注册 Filter (配置拦截哪个web资源) ----- web.xml

Filter1

cn.itcast.filter.Filter1

Filter1

/hello.jsp

3、客户端访问被拦截目标资源之前,服务器调用Filter的doFilter方法 ,执行过滤

4、Filter的doFilter方法中传入 FilterChain, 如果调用FilterChain的doFilter 就会执行目标资源,否则目标资源不会执行

chain.doFilter(request, response);

例子:

public class Demo1Filter implements Filter {

public void destroy() {

System.out.println("Demo1Filter销毁了.....");

}

public void doFilter(ServletRequest request, ServletResponse response,FilterChain chain) throws IOException, ServletException {

System.out.println("demo1filter 前");

chain.doFilter(request, response);

System.out.println("demo1filter 后");

}

}

web.xml:

Demo1Filter

com.itheima.filter.Demo1Filter

name1

value1

name2

value2

name3

value3

Demo1Filter

/*

REQUEST

FORWARD

2.过滤器设置

1)FilterChain:

在客户端访问服务器web资源时,服务器端为一个web资源,配置多个过滤器拦截 ,这多个过滤器,就会组成过滤器链 FilterChain, 调用FilterChain的doFilter 表示要执行过滤器链下一个资源,如果当前过滤器已经是链上最后一个过滤器,就会执行目标资源Tip:

web服务器根据Filter在web.xml文件中的注册顺序,决定先调用哪个Filter

2) :

过滤器拦截配置

1、如果连接目标资源是一个Servlet,可以选择url和servlet名称两种配置方式

/hello

HelloServlet

3)url-pattern:

url-pattern和 Servlet中路径写法一样,有三种 : 完全匹配、目录匹配、扩展名匹配

4):

指定过滤器所拦截的资源被 Servlet 容器调用的方式

容器调用服务器端资源 有四种方式

REQUEST、FORWARD、INCLUDE、ERROR

二.监听器1.概述

监听器就是一个java程序,功能是监听另一个java对象变化(方法调用、属性变更)public class MyHSesssionListener implements HttpSessionListener {

public void sessionCreated(HttpSessionEvent se) {

System.out.println("session对象被创建出来了..."+se.getSession());

}

public void sessionDestroyed(HttpSessionEvent se) {

System.out.println("session对象被销毁了..."+se.getSession());

}

}2.三种监听器

1.用来监听三大作用域的创建和销毁的监听器

1)ServletContextListener 用来监听ServletContext对象创建和销毁的监听器

创建:服务器启动,web应用加载后立即创建代表当前web应用的ServletContext对象

销毁:服务器关闭或web应用被移除出容器时,随着web应用的销毁而销毁

2)HttpSessionListener 用来监听HttpSession对象创建和销毁的监听器

创建:第一次调用request.getSession方法时创建代表当前会话的session对象

销毁:超过30分钟没人用销毁/调用invalidate方法自杀/服务器非正常关闭时随着web应用的销毁而销毁,如果服务器是正常关闭会被钝化起来.

Tips:

当服务器正常关闭时,还存活着的session会随着服务器的关闭被以文件的形式存储在tomcat的work目录下,这个过程叫做session的钝化。

当服务器再次正常开启时,服务器会找到之前的SESSIONS.ser文件从中恢复之前保存起来的session对象这个过程叫做session的活化。

想要随着Session被钝化活化的对象它的类必须实现Serializable接口。

3)ServletRequestListener 用来监听ServletRequest对象创建和销毁的监听

创建:请求开始创建代表请求的request对象

销毁:请求结束时代表请求的request对象销毁

2.用来监听三大作用域中属性变化的监听器

ServletContextAttributeListener

HttpSessionAttributeListener

ServletRequestAttributeListener

3.使javabean自己感知自己在Session中状态变化的监听器,这两个监听器很特殊,不需要自己去写类实现也不需要在web.xml中注册,只要使javabean实现这个接口就能起作用

1)HttpSessionBindingListener

javabean被绑定到session中

sessionDidActive(HttpSessionBindingEvent event)

javabean被移除绑定从session中

valueUnbound(HttpSessionBindingEvent event)方法

2)HttpSessionActivationListener

javabean随着session被钝化

sessionWillPassivate(HttpSessionBindingEvent event)

javabean随着session被活化

sessionDidActive(HttpSessionBindingEvent event)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值