下面代码还是以前上学时候再做一个项目时候写的代码,主要是为了做日志查询用,写了一个监听器,用来监听什么时候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+"毫秒");
}
}
今天用到了监听器,翻出了了以上的代码,贴出来,供自己和大家参考。