*1.监听器_监听三大作用于创建销毁的监听器
Servlet监听器,
监听器:监听器就是一个java程序,功能是监听另一个java对象变化(方法调用、属性变更)
8个监听器,分为了3种
1.写一个类实现响应的接口
2.注册监听器 -- 在web.xml中注册监听器
1.用来监听三大作用域的创建和销毁的监听器
ServletContextListener 用来监听ServletContext对象创建和销毁的监听器
创建:服务器启动,web应用加载后立即创建代表当前web应用的ServletContext对象
销毁:服务器关闭或web应用被移除出容器时,随着web应用的销毁而销毁
HttpSessionListener 用来监听HttpSession对象创建和销毁的监听器
创建:第一次调用request.getSession方法时创建代表当前会话的session对象
销毁:超过30分钟没人用销毁/调用invalidate方法自杀/服务器非正常关闭时随着web应用的销毁而销毁,如果服务器是正常关闭会被钝化起来.
当服务器正常关闭时,还存活着的session会随着服务器的关闭被以文件的形式存储在tomcat的work目录下,这个过程叫做session的钝化
当服务器再次正常开启时,服务器会找到之前的SESSIONS.ser文件从中恢复之前保存起来的session对象这个过程叫做session的活化
想要随着Session被钝化活化的对象它的类必须实现Serializable接口
ServletRequestListener 用来监听ServletRequest对象创建和销毁的监听
创建:请求开始创建代表请求的request对象
销毁:请求结束时代表请求的request对象销毁
例子:监听servletcontext的创建与销毁,
1)写一个类继承ServletContextListener
servletcontext什么时候创建?
创建:服务器启动,web应用加载后立即创建代表当前web应用的ServletContext对象
销毁:服务器关闭或web应用被移除出容器时,随着web应用的销毁而销毁
2.例子session监听器
HttpSessionListener 用来监听HttpSession对象创建和销毁的监听器
创建:第一次调用request.getSession方法时创建代表当前会话的session对象
销毁:超过30分钟没人用销毁/调用invalidate方法自杀/服务器非正常关闭时随着web应用的销毁而销毁,如果服务器是正常关闭会被钝化起来.
当服务器非正常关闭的时候,也会销毁session。
当服务器正常关闭时,还存活着的session会随着服务器的关闭被以文件的形式存储在tomcat的work目录下,这个过程叫做session的钝化
当服务器再次正常开启时,服务器会找到之前的SESSIONS.ser文件从中恢复之前保存起来的session对象这个过程叫做session的活化
想要随着Session被钝化活化的对象它的类必须实现Serializable接口!
可以被序列化。。。。
3.ServletRequestListener
创建:请求开始创建代表请求的request对象
销毁:请求结束时代表请求的request对象销毁
以上就是第一类监听器。
*2.监听器_监听三大作用域中属性变化的监听器_监听javabean在session中状态变化的监听器
第二类监听器,用来监听三大作用域中属性变化的监听器
ServletContextAttributeListener
HttpSessionAttributeListener
ServletRequestAttributeListener
同样session也是,sevletRequest也是。
剩下的最后一组还有两个监听器:
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)
不用再web.xml里面注册监听器了。
监听器有什么用?
很少。
案例:显示登陆列表,踢人功能。
*3.监听器案例_用户登录列表踢人案例
1.创建表
create database day14;
use day14;
create table user(
id int primary key auto_increment,
name varchar(20),
password varchar(40),
role varchar(20)
);
insert into user values(null,'a','123','user'),(null,'b','123','user'),(null,'c','123','user'),(null,'admin','123','admin');
2.分析
展示用户列表L:
隐含问题:
1.存两个用户的情况:重写user的hashcode。
2.另一个登陆,这个账号需要下线。
开发userlist界面:
ie8以上是共用内存的。所以不能新开窗口了。
踢人功能。
用的不太多,最多的是8个监听器。后面两个比较特殊。