一起谈.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

目录
相关文章
|
3月前
|
人工智能 前端开发 Devops
.NET技术在现代开发中的作用:.NET技术的核心价值、在现代应用开发中的实际应用、以及面临的挑战与未来趋势。
.NET技术是软件开发领域的核心力量,本文从其核心价值、实际应用及未来挑战三方面进行探讨。它支持多种语言,提供强大的开发工具和丰富的类库,并具备跨平台能力。在现代应用开发中,.NET广泛应用于企业级系统、Web应用、移动应用、云服务和游戏开发等领域。面对性能优化、容器化、AI集成等挑战,.NET持续创新以适应不断发展变化的技术环境。
60 4
|
3月前
|
人工智能 开发框架 .NET
.NET技术的强大功能:.NET技术的基础特性、在现代开发中的应用、以及它如何助力未来的软件开发。
.NET技术是软件开发领域的核心支柱,以其强大功能、灵活性及安全性广受认可。本文分三部分解析:基础特性如多语言支持、统一运行时环境;现代应用如企业级与Web开发、移动应用、云服务及游戏开发;以及未来趋势如性能优化、容器化、AI集成等,展望.NET在不断变化的技术环境中持续发展与创新。
115 4
|
3月前
|
人工智能 物联网 开发者
.NET技术在现代软件开发中的应用愈发广泛和深入
.NET技术是软件开发的关键支柱,本文分为三部分探讨其创新应用:最新进展如.NET 5/6统一平台、性能提升、跨平台支持增强、云集成优化及开源社区贡献;应用场景涵盖微服务架构、物联网、AI/机器学习、游戏及移动应用开发;未来发展潜力在于持续性能优化、云原生支持、新兴技术集成、生态扩张及教育培训加强。.NET正以其强大适应性和创新潜力引领软件开发的新方向。
47 3
|
3月前
|
人工智能 开发框架 .NET
如何掌握.NET技术,引领开发前沿:.NET技术的核心能力、在现代开发中的应用实践、以及如何通过.NET技术实现持续创新。
.NET技术已成为软件开发不可或缺的部分,本文分三部分探讨:核心能力如多语言支持、统一运行时环境、丰富的类库及跨平台能力;现代开发实践包括企业级应用、Web与移动开发、云服务及游戏开发;并通过性能优化、容器化、AI集成等方面实现持续创新,使开发者站在技术前沿。
63 3
|
28天前
|
人工智能 开发框架 C#
C#/.NET/.NET Core技术前沿周刊 | 第 6 期(2024年9.16-9.22)
C#/.NET/.NET Core技术前沿周刊 | 第 6 期(2024年9.16-9.22)
|
28天前
|
人工智能 开发框架 Cloud Native
C#/.NET/.NET Core技术前沿周刊 | 第 9 期(2024年10.07-10.13)
C#/.NET/.NET Core技术前沿周刊 | 第 9 期(2024年10.07-10.13)
|
24天前
|
Windows
.NET 隐藏/自定义windows系统光标
【10月更文挑战第20天】在.NET中,可以使用`Cursor`类来控制光标。要隐藏光标,可将光标设置为`Cursors.None`。此外,还可以通过从文件或资源加载自定义光标来更改光标的样式。例如,在表单加载时设置`this.Cursor = Cursors.None`隐藏光标,或使用`Cursor.FromFile`方法加载自定义光标文件,也可以将光标文件添加到项目资源中并通过资源管理器加载。这些方法适用于整个表单或特定控件。
|
28天前
|
数据可视化 NoSQL C#
C#/.NET/.NET Core技术前沿周刊 | 第 8 期(2024年10.01-10.06)
C#/.NET/.NET Core技术前沿周刊 | 第 8 期(2024年10.01-10.06)
|
28天前
|
设计模式 开发框架 C#
C#/.NET/.NET Core技术前沿周刊 | 第 4 期(2024年9.1-9.8)
C#/.NET/.NET Core技术前沿周刊 | 第 4 期(2024年9.1-9.8)
|
2月前
|
人工智能 前端开发 开发工具
解读.NET 技术的开发潜力
本文全面介绍了.NET技术在软件开发领域的核心优势、创新应用及面临的挑战。.NET以其统一的开发平台、强大的工具和跨平台能力,成为企业级应用、Web应用乃至游戏开发的理想选择。然而,在性能优化、容器化及AI集成等方面仍需不断突破。通过积极拥抱开源和社区驱动模式,.NET将持续推动软件开发的进步。
55 1