图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):
图7.应用程序级的追踪
图7显示了应用程序的最后的六个请求的追踪信息。如果要查看每个请求的细节信息,点击每一行的"View Details"链接。
注意,如果在web.config文件中trace被设置为true,并且在页面指令中它被设置为false,追踪将被禁止。
总结
ASP.NET使调试Web应用程序容易多了。现在你已经知道了如何使用追踪,试用一下,看看它把你的效率提高了多少!
您可能感兴趣的文章: