当前位置: 首页 > 图文教程 > 网络编程 > ASP > ASP.NET编程实例ABC(3)

ASP
ASP调用ORACLE存储过程并返回结果集
用ASP实现网页BBS
关于Global.asa文件的深入研究与session变量失效提示的具体方法
简易ASP+注册系统
防护手册:如何防止ASP木马在服务器上运行
用Visual Basic实现多画面播放功能之二
如何增强ASP程序性能(1)
如何增强ASP程序性能(2)
如何增强ASP程序性能(3)
ASP备份数据库
二十八条改善 ASP 性能和外观的技巧
在Form域中Post大于100K的数据
如何使用ASP制作模似动态生长的表单?
Microsoft IIS 真的如此「不安全」吗?(1)
Microsoft IIS 真的如此「不安全」吗?(2)
Microsoft IIS 真的如此「不安全」吗?(3)
Microsoft IIS 真的如此「不安全」吗?(4)
Microsoft IIS 真的如此「不安全」吗?(5)
关于页面和代码分离
ServerVariables 对路径的操作

ASP.NET编程实例ABC(3)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 32 ::
收藏到网摘: n/a

      
  
  
  在 ASP.NET中显示事件日志记录
  在Windows 2000 或 NT中,事件日志对于管理员来说几乎是最重要的信息来源,因为所有发生的事件都在那里进行记录,无论是成功的操作,还是灾难性的失败。既然如此,你是否想过让这些信息在Web上呈现出来? 是的,这是很有意义的事情。
  我们都应该很熟悉下面的事件阅读器了,下面就示范如何使用AP.NET和.NET Framework SDK来美观、清晰地模仿其条目列表。我还给读者留下一个练习题,为一个条目的完整细节构造一个页面。
  
  
  较粗笨的方法
  如果必须又快又粗略地完成任务,那么完全可以利用ASP语言的相关技术来生成一个事件列表(甚至可以用表格,但是这个例子没有那样做)。程序的名字是 simple.aspx,代码如下:
  <% @Page Language="C#" %>
  <% @Import Namespace="System.Diagnostics" %>
  <%
  EventLog aLog = new EventLog();
  aLog.Log = "System";
  aLog.MachineName = "."; // Lokale Maschine
  string strImage = ""; // Icon für das Event
   
  Response.Write("<p>There are " + aLog.Entries.Count +
  " entries in the System event log.</p>");
   
  foreach (EventLogEntry entry in aLog.Entries)
  {
  switch (entry.EntryType)
  {
  case EventLogEntryType.Warning:
  strImage = "warning.png";
  break;
  case EventLogEntryType.Error:
  strImage = "error.png";
  break;
  default:
  strImage = "info.png";
  break;
  }
  Response.Write("<img src=\"" + strImage + "\"> | ");
  Response.Write(entry.TimeGenerated.ToString() + " | ");
  Response.Write(entry.Source + " | ");
  Response.Write(entry.EventID.ToString() + "<br>\r\n");
  }
  %>
  事件日志类可以在名称空间System.Diagnostics(系统诊断)中找到,这一部分在页面的开始定义。打开日志本身很直观:创建一个新EventLog对象,指定Log 和 MachineName ("." 是本地机器的意思)。到此我们可以读取事件日志的内容了。
  这将在一个 foreach循环中完成。我们在每个条目之前都放置一个图标,这样列表看起来就不至于那么平淡。另外,条目的列表顺序与通常的事件阅读器顺序相反:在这里,最老的条目列在最前面。
  使用DataGrid来设计得更美观
  ASP.NET带来了许多创新功能,尤其是在显示数据方面。比如,要显示的数据并不总是必须出自数据库。DataGrid Web Control 也是如此,正如其名称所示,它可以创建一个来自数据的表格或者栅格。唯一的前提是数据源要支持Icollection接口,而EventLog (事件日志)的Entries Collection(条目集合 )正是满足这一要求的。
  以下的文件datagrid.aspx演示了使用DataGrid是如何得简单:
  <% @Page Language="C#" %>
  <% @Import Namespace="System.Diagnostics" %>
  <script language="C#" runat="server">
  void Page_Load(Object sender, EventArgs e)
  {
  EventLog aLog = new EventLog();
  aLog.Log = "System";
  aLog.MachineName = ".";
   
  LogGrid.DataSource = aLog.Entries;
  LogGrid.DataBind();
  }
  </script>
  <body bgcolor="#ffffff">
   
  <h3>System Event Log</h3>
   
  <form runat="server">
  <ASP:DataGrid id="LogGrid" runat="server"
  BorderColor="black"
  BorderWidth="1"
  GridLines="Both"
  CellPadding="3"
  CellSpacing="0"
  Font-Name="Verdana"
  Font-Size="8pt"
  HeaderStyle-BackColor="#aaaadd"
  />
  </form>
   
  </body>
  </html>