标签:image required java logger err 示例 自己 exti 启动
监听器,字面上的理解就是监听观察某个事件(程序)的发生情况,当被监听的事件真的发生了的时候,事件发生者(事件源) 就会给注册该事件的监听者(监听器)发送消息,告诉监听者某些信息,同时监听者也可以获得一份事件对象,根据这个对象可以获得相关属性和执行相关操作。
监听器模型涉及以下三个对象:
(1)事件:用户对组件的一个操作,或者说程序执行某个方法,称之为一个事件,如机器人程序执行工作。
(2)事件源:发生事件的组件就是事件源,也就是被监听的对象,如机器人可以工作,可以跳舞,那么就可以把机器人看做是一个事件源。
(3)事件监听器(处理器):监听并负责处理事件的方法,如监听机器人工作情况,在机器人工作前后做出相应的动作,或者获取机器人的状态信息。
javaweb中的监听器:
监听器用于监听web应用中某些对象、信息的创建、销毁、增加,修改,删除等动作的发生,然后作出相应的响应处理。当范围对象的状态发生变化的时候,服务器自动调用监听器对象中的方法。常用于统计在线人数和在线用户,系统加载时进行信息初始化,统计网站的访问量等等。
javaweb监听器的分类:
按监听的对象划分,可以分为
按监听的事件划分
JavaWeb中的监听器:
附:常用监听器
除了上面监听session建立与销毁的listener外,还有以下几个常用的监听器。
1:监听session属性的增加、移除以及属性值改变的HttpSessionAttributeListener
2:监听web上下文的初始化(服务器已准备好接收请求)与销毁的ServletContextListener
3:监听web上下文属性的增加、删除、属性值变化的ServletContextAttributeListener
4:监听request的创建与销毁的ServletRequestListener
5:监听request的属性的增加、删除、属性值变化的ServletRequestAttributeListener
示例1、:用监听器统计网站在线人数
原理:每当有一个访问连接到服务器时,服务器就会创建一个session来管理会话。那么我们就可以通过统计session的数量来获得当前在线人数。所以这里用到的是HttpSessionListener。
1:创建监听器类,实现HttpSessionListener接口。
2:重写监听器类中的方法
public class onLineCount implements HttpSessionListener { public int count=0;//记录session的数量 public void sessionCreated(HttpSessionEvent arg0) {//监听session的创建 count++; arg0.getSession().getServletContext().setAttribute("Count", count); } @Override public void sessionDestroyed(HttpSessionEvent arg0) {//监听session的撤销 count--; arg0.getSession().getServletContext().setAttribute("Count", count); } }
3:在web.xml中配置监听器。注意:监听器>过滤器>serlvet,配置的时候要注意先后顺序(自己也没验证过,不知道到底是不是)
<listener> <listener-class>com.ygj.control.onLineCount</listener-class> </listener>
在Servlet3.0中,监听器的配置可以直接在代码中通过注解来完成,无需在web.xml中再配置。
@WebListener //在此注明以下类是监听器 public class onLineCount implements HttpSessionListener { public int count=0;//记录session的数量 public void sessionCreated(HttpSessionEvent arg0) {//监听session的创建 count++; arg0.getSession().getServletContext().setAttribute("Count", count); } @Override public void sessionDestroyed(HttpSessionEvent arg0) {//监听session的撤销 count--; arg0.getSession().getServletContext().setAttribute("Count", count); } }
示例2、监听服务器的状态
@WebListener public class ServerListener implements ServletContextListener { private static Logger log = Logger.getLogger("com.yb.fw.app.helper.ServerListener"); @Override public void contextDestroyed(ServletContextEvent sce) { log.info("----------服务器停止----------"); } @Override public void contextInitialized(ServletContextEvent sce) { log.info("----------服务器启动----------"); sce.getServletContext().setAttribute(FwConstant.SERVER_BROWER_LIST, new HashMap<String, HttpSession>());//初始化SESSION列表 sce.getServletContext().setAttribute(FwConstant.SERVER_USER_LIST, new HashMap<String, HttpSession>());// //初始化SESSION列表 System.out.println("自定义监听器启动:"); WebApplicationContextUtils.getRequiredWebApplicationContext(sce.getServletContext()).getAutowireCapableBeanFactory().autowireBean(this);
}
}
标签:image required java logger err 示例 自己 exti 启动
原文地址:https://www.cnblogs.com/zouhong/p/11869747.html