//------------------------------------------------------------------------------ // 此代码版权(除特别声明或在XREF结尾的命名空间的代码)归作者本人若汝棋茗所有 // 源代码使用协议遵循本仓库的开源协议及附加协议,若本仓库没有设置,则按MIT开源协议授权 // CSDN博客:https://blog.csdn.net/qq_40374647 // 哔哩哔哩视频:https://space.bilibili.com/94253567 // Gitee源代码仓库:https://gitee.com/RRQM_Home // Github源代码仓库:https://github.com/RRQM // API首页:https://www.yuque.com/rrqm/touchsocket/index // 交流QQ群:234762506 // 感谢您的下载和使用 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------ using System; using System.Text; namespace TouchSocket.Core { /// /// 快捷日志 /// public class EasyLogger : LoggerBase { private readonly Action m_action; private readonly Action m_action1; /// /// 构造函数 /// /// 参数依次为:日志类型,触发源,消息,异常 public EasyLogger(Action action) { m_action = action; } /// /// 构造函数 /// /// 参数为日志消息输出。 public EasyLogger(Action action) { m_action1 = action; } /// /// /// /// /// /// /// protected override void WriteLog(LogType logType, object source, string message, Exception exception) { try { if (m_action != null) { m_action.Invoke(logType, source, message, exception); return; } if (m_action1 != null) { StringBuilder stringBuilder = new StringBuilder(); stringBuilder.Append(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss ffff")); stringBuilder.Append(" | "); stringBuilder.Append(logType.ToString()); stringBuilder.Append(" | "); stringBuilder.Append(message); if (exception != null) { stringBuilder.Append(" | "); stringBuilder.Append($"【异常消息】:{exception.Message}"); stringBuilder.Append($"【堆栈】:{(exception == null ? "未知" : exception.StackTrace)}"); } stringBuilder.AppendLine(); m_action1.Invoke(stringBuilder.ToString()); return; } } catch { } } } }