C# 系统错误日志处理类

编写软件,难免会有一些异常,针对异常我们在实际的开发中相比都有一些,捕获异常的处理办法。把软件运行错误信息写成一个

错误日志文件很有必要。当我们在客户那边安装调试时就会更加快捷的,知道错误在哪里。否则你怎么知道软件运行哪里不正常,难道

还要在客户机器上装个开发环境调试一番吗?日志处理类,简单几行代码的事,不要手懒!

复制代码
 1     public class WriteLog
 2     {
 3         /// <summary>
 4         /// 创建日志文件
 5         /// </summary>
 6         /// <param name="ex">异常类</param>
 7         public static void CreateLog(Exception ex)
 8         {
 9             string path = Application.StartupPath+"\\log";
10             if (!Directory.Exists(path))
11             {
12                 //创建日志文件夹
13                 Directory.CreateDirectory(path);
14             }
15             //发生异常每天都创建一个单独的日子文件[*.log],每天的错误信息都在这一个文件里。方便查找
16             path += "\\"+DateTime.Now.ToShortDateString() + ".log";
17             WriteLogInfo(ex, path);
18         }
19         /// <summary>
20         /// 写日志信息
21         /// </summary>
22         /// <param name="ex">异常类</param>
23         /// <param name="path">日志文件存放路径</param>
24         private static void WriteLogInfo(Exception ex, string path)
25         {
26             using (StreamWriter sw = new StreamWriter(path, true, Encoding.Default))
27             {
28                 sw.WriteLine("*****************************************【" 
+ DateTime.Now.ToLongTimeString()
+ "】*****************************************"); 29 if (ex != null) 30 { 31 sw.WriteLine("【ErrorType】" + ex.GetType()); 32 sw.WriteLine("【TargetSite】" + ex.TargetSite); 33 sw.WriteLine("【Message】" + ex.Message); 34 sw.WriteLine("【Source】" + ex.Source); 35 sw.WriteLine("【StackTrace】" + ex.StackTrace); 36 } 37 else 38 { 39 sw.WriteLine("Exception is NULL"); 40 } 41 sw.WriteLine(); 42 } 43 } 44 }
复制代码
posted @   Xingsoft  阅读(5554)  评论(2编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
点击右上角即可分享
微信分享提示