Servlet监听器的接口
创始人
2024-04-13 06:11:21
0

Web应用服务器会产生各种事件,如Web容器启动事件、session过期事件、请求到达事件等等。我们已经在《JBuilder 2005实战JSP开发》中阐述了这些事件的接口,事件处理方法使程序对Web应用服务器的控制能力大为提高。

在这一节里,我们监听Web容器启动关闭的事件,在事件发生时记录Web应用程序启动和关闭的系统日志,以便系统管理员通过这个日志查看Web应用程序的启动和关闭情况。日志以Excel文件格式保存在D:/serverLog的目录下。当登录成功后,用户可以将这份日志以附件的形式下载下来,下载Excel日志文件的功能将在本专题的最后一节实现。下面我们来创建这个记录系统日志的Servlet监听器。

1.启动创建Servlet监听器的向导

通过File->New...->Web->双击Listener Servlet图标启动创建Servlet监听器的向导

这一步和创建标准Servlet类似,我们指定监听器的类名为:SrvStart Listener,包名为bookstore.servlet,按Next到下一步。

2.指定Servlet监听器实现的事件接口

因为Web容器的启动和关闭事件是ServletContextListener接口定义的,所以我们选择这个接口,按Finish创建这个监听器。

打开向导创建的SrvStar tListener.java,并录入下面粗体的代码:

  1. package bookstore.servlet;  
  2. …  
  3. import java.io.*;  
  4. import java.util.*;  
  5. import java.text.SimpleDateFormat;  
  6. public class SrvStartListener  
  7. extends HttpServlet implements ServletContextListener  
  8. {  
  9. public void contextInitialized(ServletContextEvent sce)  
  10. {  
  11. GregorianCalendar cal = new GregorianCalendar();  
  12. int year = cal.get(Calendar.YEAR);//得到当前年份  
  13. int month = cal.get(Calendar.MONTH)+1;//得到当前月份  
  14. File file = new File("D:\\serverLog\\log_"+year+"_"+month+".xls");  
  15. FileWriter fw = null;  
  16. try  
  17. {  
  18. //如果文件存在,日志追加到文件末尾,否则创建新的文件  
  19. fw = new FileWriter(file,true);  
  20. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
  21. String starttime = sdf.format(new Date());  
  22. fw.write("于"+starttime+"启动Web容器\n");  
  23. } catch (IOException ex)  
  24. {  
  25. ex.printStackTrace();  
  26. } finally  
  27. {  
  28. try  
  29. {  
  30. if (fw != null)  
  31. {  
  32. fw.close();  
  33. }  
  34. } catch (IOException ex1)  
  35. {  
  36. ex1.printStackTrace();  
  37. }  
  38. }  
  39. }  
  40. …  

【编辑推荐】

  1. Servlet 2.5版本终止响应
  2. 创建Servlet过滤器的向导
  3. 浅谈user cache Servlet
  4. 过滤器解压缩Servlet和JSP页面内容
  5. Servlet的Context与Config

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...