调试ASP.NET应用程序的方法和技巧(2)

调试ASP.NET应用程序的方法和技巧


图5.使用Warn()方法用红色显示跟踪信息

 

  对跟踪信息排序

  把多个跟踪语句放在一个应用程序中有时会显得杂乱。如果你的跟踪信息可以被分为不同的类别,那么跟踪就更容易了。Trace类允许我们基于种类对跟踪信息进行分类和排序。

  下面的例子演示了如何对跟踪信息按类别进行分组:

Private Sub Page_Load(ByVal sender As System.Object, _
ByVal e As System.EventArgs) _
Handles MyBase.Load
 Trace.TraceMode = TraceMode.SortByCategory
 '此处放置初始化页面的用户代码
 Trace.Warn("Page_Load", "Page loaded")
 If Not IsPostBack Then
  ' 执行一些操作
  Trace.Warn("Page_Load", "Not in a postback")
 Else
  Trace.Warn("Page_Load", "In a postback")
 End If
End Sub

Private Sub ListBox1_SelectedIndexChanged(ByVal sender _
As System.Object, ByVal e As _
System.EventArgs) Handles _
 ListBox1.SelectedIndexChanged
 Trace.Warn("ListBox", "Listbox postback")
End Sub
 

  执行这个例子的时候,将显示下面的调试信息,它根据类别分组了(图6所示):


图6.按类别排序

 

  让我们分析上面的代码:

Trace.TraceMode = TraceMode.SortByCategory  

  TraceMode属性设置了跟踪支持的模式:

  · SortByCategory:根据类型对跟踪信息排序 。

  · SortByTime: 根据执行次序对跟踪信息进行显示。

  因为我们选择了根据类别排序模式,因此图7显示了信息按类别排序了。

Trace.Warn("Page_Load", "Page loaded")  

  Warn属性把消息显示为红色,注意这是个重载的方法。在例子中,我们给它传递了两个参数。第一个输入类别(Category),第二个参数是为取得消息(Message)的。

  除了使用Trace类设置跟踪模式之外,你还可以使用页面指令指定跟踪模式:

<%@ Page Language="vb" Trace="true" TraceMode="SortByCategory" AutoEventWireup="false" Codebehind="WebForm1.aspx.vb" Inherits="WebApplication1.WebForm1" %>  

  应用程序跟踪

  最后一部分讨论了页面追踪,它追踪页面内的执行信息流。ASP.NET同时支持应用程序级的追踪,应用程序级的追踪在web.config文件中设置,在trace段下面:

 

  为了激活应用程序级追踪,设置下面的值:

属性     描述  
Enabled   True   激活或禁止应用程序级追踪。  
requestLimit   10   设置追踪的请求的最大数量。  
pageOutput   False   在页面的末尾显示追踪信息。  
traceMode   sortByTime   追踪信息排序方式。  
localOnly   True   设置在非本地计算机上查看追踪浏览器的能力。  

  当应用程序被载入后,追踪信息没有显示在页面上。为了查看追踪信息,我们需要使用追踪查看器(trace.axd):

调试ASP.NET应用程序的方法和技巧


图7.应用程序级的追踪

 

  图7显示了应用程序的最后的六个请求的追踪信息。如果要查看每个请求的细节信息,点击每一行的"View Details"链接。

  注意,如果在web.config文件中trace被设置为true,并且在页面指令中它被设置为false,追踪将被禁止。

  总结

  ASP.NET使调试Web应用程序容易多了。现在你已经知道了如何使用追踪,试用一下,看看它把你的效率提高了多少!

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wjfxfx.html