在我们的例子中,跟踪信息没有很显目的显示,因此它被其它的跟踪信息掩埋了。Trace类的Warn()方法可以把跟踪信息打印为红色。因此不是这样编写代码:
| Trace.Write("Page loaded") |
而是:
| Trace.Warn("Page loaded") |
图5显示了Warn()方法用红色显示的调试信息。
![]() 图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应用程序容易多了。现在你已经知道了如何使用追踪,试用一下,看看它把你的效率提高了多少!
文章整理:西部数码--专业提供域名注册、虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!







