监听器用法(listener)应用到j2ee项目中

下面代码还是以前上学时候再做一个项目时候写的代码,主要是为了做日志查询用,写了一个监听器,用来监听什么时候ip地址为什么的访问了哪些页面,以及哪位管理员对网站做了什么操作等等,代码很简单,适合初学者看,代码内容具体如下,不多解释,相信都可以看得懂。

public class Listener implements HttpSessionListener,ServletContextListener,
			ServletRequestListener {
	Log log=LogFactory.getLog(getClass());    //日志记录器
	//创建sesion的时候被调用
	public void sessionCreated(HttpSessionEvent se) {
		// TODO Auto-generated method stub
		HttpSession session=se.getSession();
		log.info("新建的session的ID为:"+session.getId());
		
	}
	
	public void sessionDestroyed(HttpSessionEvent se) {
		// TODO Auto-generated method stub
		HttpSession session=se.getSession();
		log.info("销毁的session的ID为:"+session.getId());
		
	}
	//加载servlet上下文的时候被调用
	public void contextDestroyed(ServletContextEvent sce) {
		// TODO Auto-generated method stub
		ServletContext context=sce.getServletContext();
		log.info("即将关闭:"+context.getContextPath());
		
	}

	public void contextInitialized(ServletContextEvent sce) {
		// TODO Auto-generated method stub
		ServletContext context=sce.getServletContext();
		log.info("即将开启:"+context.getContextPath());
		
	}
	//创建request的时候被调用
	public void requestInitialized(ServletRequestEvent sre) {
		// TODO Auto-generated method stub
		HttpServletRequest httpServletRequest=(HttpServletRequest) sre.getServletRequest();
		String url=httpServletRequest.getRequestURI();//访问的路径
		url=httpServletRequest.getQueryString()==null? url:(url+"?"+httpServletRequest.getQueryString());
		httpServletRequest.setAttribute("dateCreate", System.currentTimeMillis());
		log.info("IP地址为:"+httpServletRequest.getRemoteAddr()+"请求"+url);
	}
	public void requestDestroyed(ServletRequestEvent sre) {
		// TODO Auto-generated method stub
		HttpServletRequest httpServletRequest=(HttpServletRequest) sre.getServletRequest();
		Long time=System.currentTimeMillis()-(Long)httpServletRequest.getAttribute("dateCreate");
		log.info(httpServletRequest.getRemoteAddr()+"请求结束,耗时:"+time+"毫秒");
	}


	

}


 今天用到了监听器,翻出了了以上的代码,贴出来,供自己和大家参考。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值