1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | using System; using System.IO; using System.Text; namespace Controls.Helper { public class LoggerHelper { private static object o = new object (); private static string GetLogFilePath() { string filePath = AppDomain.CurrentDomain.BaseDirectory + @"\Log\ExeConfig\" ; //判断路径、文件是否存在,如不存在则生成相关资源 if (!Directory.Exists(filePath)) { Directory.CreateDirectory(filePath); } //设置文件名 string currtime = DateTime.Now.ToString( "yyyyMMdd" ); filePath = filePath +currtime + ".log" ; if (!File.Exists(filePath)) { FileStream fs = File.Create(filePath); fs.Close(); } return filePath; } public static void WriteLog( string errorStr, Exception e) { try { lock (o) { string filepath = GetLogFilePath(); StreamWriter writer = new StreamWriter(filepath, true , Encoding.GetEncoding( "utf-8" )); string title = string .Format( "================================{0}================================" , DateTime.Now.ToString( "yyyy-MM-dd HH:mm:ss:fff" )); writer.WriteLine( string .Empty); writer.WriteLine(title); writer.WriteLine( string .Format( "错误内容:{0}" , errorStr)); if (e != null ) { writer.WriteLine( string .Format( "异常信息:{0}" , e.ToString())); writer.WriteLine( string .Format( "错误消息: {0}" , e.Message + (e.InnerException == null ? "" : e.InnerException.Message))); writer.WriteLine( string .Format( "调用堆栈: {0}" , e.StackTrace)); } writer.WriteLine(title); writer.WriteLine( string .Empty); writer.Flush(); writer.Close(); } } catch (Exception ex) { } } } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构