Skip to main content

Tracing in ASP.Net

1. To enable tracing for the application, use the element in the Web.config file or machine.config file.
<trace enabled="true" pageOutput="true false" />

2. To enable tracing for a single page, use the attributes of the @Page directive of that page.

<%@ Page Trace="true" Language= ... %>
3. In your code, add custom trace messages where appropriate using the Write and Warn methods of the Trace object.

In Visual Basic .NET:
Trace.Write("Custom Trace", "Beginning User Code...")
Trace.Warn("Custom Trace", "Array count is null!")
In C#:
Trace.Write("Custom Trace", "Beginning User Code...");
Trace.Warn("Custom Trace", "Array count is null!");

Optionally, use the IsEnabled property provided by the current page's TraceContext object (accessed by using the Trace property of the Page object).
In Visual Basic .NET:
If Trace.IsEnabled Then
strMsg = "Tracing is enabled"
Trace.Write("myTrace", strMsg)
End If

In C#:
if (Trace.IsEnabled)
{
strMsg = "Tracing is enabled";
Trace.Write("myTrace", strMsg);
}

View and analyze the trace information. If the pageOutput property was set to true, then trace information will be displayed at the bottom of the Web page. If it was set to false, then it will be displayed in a separate log file, named trace.axd, and located here:
http://ServerName/ApplicationName/trace.axd

DebugGuru

Popular posts from this blog

Searching Unicode characters in Oracle table

Oracle implementation of Regular expression has no support for using hexadecimal code to search for Unicode characters. The only way to search for Unicode character is it use the character itself. Normally with Regular expression, you can use \x or \u followed by hexadecimal code to search for any character. E.g. \x20 will match space. But REGEXP_LIKE in Oracle does not support \x. You need to use unistr function to convert the code to equivalent character and then use it with REGEXP_LIKE. E.g. REGEXP_LIKE(source,'[' ||unistr('\0020')|| ']');

C# Performance Improvement - The Power of StringBuilder

 Often when we are wring code we don't think about performance and go with the default options available to achieve a task. String concatenation is one such scenario. If you are doing simple and few string catenations, then you can use the following result = string1 + string2; string1+= string2; result = String.Concat(string1,string2); String.Format and string interpolation are few other options.  However when you are performing large and repetitive  operation, string catenation can be expensive. Here is an example to prove the point.  As you can see it took 41 seconds to perform 100k string catenation. Now lets replace this with StringBuilder and see.  8 ms!!!!!! That is a massive performance difference. Hope you get the point. More info on StringBuilder can be found here https://learn.microsoft.com/en-us/dotnet/api/system.text.stringbuilder?view=net-7.0

System.Configuration in .Net Framework 2 onwards

Often application need custom configuration section. System.Configuration namespace includes classes for reading and writing configuration settings. There is a slight difference in how you use this namespace depending on the Framework version you are using Prior to .Net Framework 2.0, the .Net Framework included System.Configuration namespace, but that version of the namespace is now outdated. If you simply add the System.configuration namespace to your project (using in C#), your application references the outdated namespace. To refer to the updated namespace, follow these steps 1. In VS, open the project that requires System.Configuration namespace. 2. Click on the Project menu and then click Add Reference 3. On the .Net tab, Select System.Configuration as shown in following figure, and click OK 4. Now add the System.Configuration namespace to your project normally using Imports (in VB) or using (in C#) and your application will reference the correct version of the namespa...