一起谈.NET技术,一步一步教你实现简单的自定义错误跟踪

简介: 一、设计xml,应该包含下面信息:1、Datetime:  发生错误/异常的日期和时间2、File name: 发生错误/异常的文件名3、Class name : 发生错误/异常的类名4、Methodname: 发生错误/异常的方法名5、Errormethod :  包含错误代码的函数名字6、Me...

一、设计xml,应该包含下面信息:

1、Datetime:  发生错误/异常的日期和时间
2、File name: 发生错误/异常的文件名
3、Class name : 发生错误/异常的类名
4、Methodname: 发生错误/异常的方法名
5、Errormethod :  包含错误代码的函数名字
6、Message :错误/异常的信息
7、Error details: 错误/异常详情
8、IP : 客户端IP地址
9、URL : 发生错误的URL

DemoXML:

DemoXML
xml version="1.0" encoding="utf-8"?>
<errorlog>
  
<error>
    
<datetime>datetime datetime>
    
<filename>filename filename>
    
<classname>classname classname>
    
<methodname>methodname methodname>
    
<errormethod>errormethod errormethod>
    
<messsage>ErrorMessage messsage>
    
<errordetails>Details goes here errordetails>
    
<IP>IP adress IP>
    
<url>URL url>
  
error>
errorlog>

二、设计错误处理类:errorHandler.cs,里面的WriteError方法需要Exception和FileName两个参数:

errorHandler.cs
using  System; 
using  System.Collections.Generic; 
using  System.Text; 
using  System.Xml; 
using  System.Reflection; 
using  System.Diagnostics; 
namespace  code_center 

    
public   class  errorHandler 
    { 
        
string  _strErrorMessage, _strDetails, _strClassName, _strMethodName; 
        DateTime _dtOccuranceTime 
=   new  DateTime(); 
        
public  errorHandler() 
        { 
        } 
        
public  errorHandler(DateTime time,  string  className,  string  methodName,
            
string  errorMessage,  string  details) 
        { 
            _dtOccuranceTime 
=  time; 
            _strClassName 
=  className; 
            _strDetails 
=  details; 
            _strErrorMessage 
=  errorMessage; 
            _strMethodName 
=  methodName; 
        } 
        
public   static   void  WriteError(Exception ex) 
        { 
            WriteError(ex, 
"" ); 
        } 
        
public   static   void  WriteError(Exception ex,  string  fileName) 
        { 
            XmlDocument doc 
=   new  XmlDocument(); 
            
string  strRootPath  =
           System.Configuration.ConfigurationManager.AppSettings[
" logfilepath " ].ToString(); 
            
string  xmlPath  =  System.Web.HttpContext.Current.Server.MapPath(strRootPath); 
            doc.Load(@xmlPath); 
            XmlNode newXMLNode, oldXMLNode; 
            oldXMLNode 
=  doc.ChildNodes[ 1 ].ChildNodes[ 0 ]; 
            newXMLNode 
=  oldXMLNode.CloneNode( true ); 
            StackTrace stackTrace 
=   new  StackTrace(); 
            StackFrame stackFrame 
=  stackTrace.GetFrame( 1 ); 
            MethodBase methodBase 
=  stackFrame.GetMethod(); 
            newXMLNode.ChildNodes[
0 ].InnerText  =  DateTime.Now.ToString(); 
            newXMLNode.ChildNodes[
1 ].InnerText  =  fileName; 
            newXMLNode.ChildNodes[
2 ].InnerText  =  methodBase.DeclaringType.FullName; 
            newXMLNode.ChildNodes[
3 ].InnerText  =  methodBase.Name; 
            newXMLNode.ChildNodes[
4 ].InnerText  =  ex.TargetSite.Name; 
            newXMLNode.ChildNodes[
5 ].InnerText  =  ex.Message; 
            newXMLNode.ChildNodes[
6 ].InnerText  =  ex.StackTrace; 
            newXMLNode.ChildNodes[
7 ].InnerText  =  System.Web.HttpContext.Current.Request.UserHostAddress; 
            newXMLNode.ChildNodes[
8 ].InnerText  =  System.Web.HttpContext.Current.Request.Url.OriginalString; 
            doc.ChildNodes[
1 ].AppendChild(newXMLNode); 
            doc.Save(@xmlPath); 
            doc.RemoveAll(); 
        } 
    } 

三、 在Web.config加入:

     < appSettings >
        
< add  key ="logfilepath"  value ="~/errorHandling/errorlog.xml" />
    
appSettings>

四、测试:在你的网站中加入两段测试代码

1、在Page_Load:

Page_Load
     public   partial   class  _Default : System.Web.UI.Page
    {
        
protected   void  Page_Load( object  sender, EventArgs e)
        {
            
try
            {
                
throw   new  Exception( " Custom error " );
            }
            
catch  (Exception ex)
            {
                Response.Write(ex.Message);
                kirin.errorHandler.WriteError(ex, 
" Default.aspx.cs " );
            }
        } 
    }

2、在Application_Error中加入:

     void  Application_Error( object  sender, EventArgs e) 
    { 
        code_center.errorHandler.WriteError(Server.GetLastError().GetBaseException(),
            
" Global.asax " ); 
    } 

3、Page_Load异常的结果:

errorXML
   < error >
    
< datetime > 2010-1-29 9:29:24 datetime>
    
<filename>Default.aspx.vb filename>
    
<classname>kirin._Default classname>
    
<methodname>Page_Load methodname>
    
<errormethod>Page_Load errormethod>
    
<messsage>Custom error messsage>
    
<errordetails>   在 kirin._Default.Page_Load(Object sender, EventArgs e) 位置 C:\Demo\kirin_code_center\kirin\Default.aspx.cs:行号 16 errordetails>
    
<IP>127.0.0.1 IP>
    
<url>http://localhost:2192/default.aspx url>
error>

五、完整代码/Files/zhuqil/kirin_errorHandler.rar

目录
相关文章
|
10天前
|
JSON 安全 API
.net 自定义日志类
在.NET中,创建自定义日志类有助于更好地管理日志信息。示例展示了如何创建、配置和使用日志记录功能,包括写入日志文件、设置日志级别、格式化消息等。注意事项涵盖时间戳、日志级别、JSON序列化、线程安全、日志格式、文件处理及示例使用。请根据需求调整代码。
36 13
|
11天前
|
开发框架 算法 .NET
C#/.NET/.NET Core技术前沿周刊 | 第 15 期(2024年11.25-11.30)
C#/.NET/.NET Core技术前沿周刊 | 第 15 期(2024年11.25-11.30)
|
11天前
|
开发框架 Cloud Native .NET
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
|
2月前
|
自然语言处理 物联网 图形学
.NET 技术凭借其独特的优势和特性,为开发者们提供了一种高效、可靠且富有创造力的开发体验
本文深入探讨了.NET技术的独特优势及其在多个领域的应用,包括企业级应用、Web应用、桌面应用、移动应用和游戏开发。通过强大的工具集、高效的代码管理、跨平台支持及稳定的性能,.NET为开发者提供了高效、可靠的开发体验,并面对技术更新和竞争压力,不断创新发展。
89 7
|
2月前
|
开发框架 安全 .NET
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱。它不仅加速了应用开发进程,提升了开发质量和可靠性,还促进了创新和业务发展,培养了专业人才和技术社区,为软件开发和数字化转型做出了重要贡献。
39 5
|
2月前
|
传感器 人工智能 供应链
.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。
本文深入探讨了.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。通过企业级应用、Web应用及移动应用的创新案例,展示了.NET在各领域的广泛应用和巨大潜力。展望未来,.NET将与新兴技术深度融合,拓展跨平台开发,推动云原生应用发展,持续创新。
49 4
|
2月前
|
开发框架 .NET C#
.NET 技术凭借高效开发环境、强大框架支持及跨平台特性,在软件开发中占据重要地位
.NET 技术凭借高效开发环境、强大框架支持及跨平台特性,在软件开发中占据重要地位。从企业应用到电子商务,再到移动开发,.NET 均展现出卓越性能,助力开发者提升效率与项目质量,推动行业持续发展。
38 4
|
2月前
|
机器学习/深度学习 人工智能 物联网
.NET 技术:引领未来开发潮流
.NET 技术以其跨平台兼容性、高效的开发体验、强大的性能表现和安全可靠的架构,成为引领未来开发潮流的重要力量。本文深入探讨了 .NET 的核心优势与特点,及其在企业级应用、移动开发、云计算、人工智能等领域的广泛应用,展示了其卓越的应用价值和未来发展前景。
67 5
|
2月前
|
机器学习/深度学习 人工智能 Cloud Native
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台。本文深入解析 .NET 的核心优势,探讨其在企业级应用、Web 开发及移动应用等领域的应用案例,并展望未来在人工智能、云原生等方面的发展趋势。
46 3
|
2月前
|
敏捷开发 缓存 中间件
.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素
本文深入探讨了.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素,并通过企业级应用和Web应用开发的实践案例,展示了如何在实际项目中应用这些模式,旨在为开发者提供有益的参考和指导。
43 3