using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Text; using System.Threading.Tasks; using XdCxRhDW.Dto; using XdCxRhDW.Entity; using XdCxRhDW.Repostory; namespace XdCxRhDW.App { public static class LogHelper { public static async Task Info(string msg) { var pro = Process.GetCurrentProcess(); try { using (RHDWLogContext db = new RHDWLogContext()) { LogRes res = new LogRes() { LogTime = DateTime.Now, Module = pro.ProcessName, LogType = EnumLogType.Info, Msg = msg, }; db.LogRes.Add(res); await db.SaveChangesAsync(); } } catch (Exception ex) { Serilog.Log.Error(ex, "日志信息写入异常"); } Serilog.Log.Information(msg); } public static async Task Warning(string msg, Exception ex = null) { var pro = Process.GetCurrentProcess(); try { using (RHDWLogContext db = new RHDWLogContext()) { LogRes res = new LogRes() { LogTime = DateTime.Now, Module = pro.ProcessName, LogType = EnumLogType.Warning, Msg = msg, }; db.LogRes.Add(res); await db.SaveChangesAsync(); } } catch (Exception arg) { Serilog.Log.Error(arg, "日志信息写入异常"); } Serilog.Log.Warning(ex, msg); } public static async Task Error(string msg, Exception ex = null) { if (ex != null && ex.GetType() == typeof(AggregateException)) { var iex = (ex as AggregateException).InnerExceptions.FirstOrDefault(); if (iex != null) ex = iex; } var pro = Process.GetCurrentProcess(); try { using (RHDWLogContext db = new RHDWLogContext()) { LogRes res = new LogRes() { LogTime = DateTime.Now, Module = pro.ProcessName, LogType = EnumLogType.Error, Msg = msg, }; db.LogRes.Add(res); await db.SaveChangesAsync(); } } catch (Exception arg) { Serilog.Log.Error(arg, "日志信息写入异常"); } Serilog.Log.Error(ex, msg); } } }