using Microsoft.Extensions.Logging; using WIDESEAWCS_Core.LogHelper; namespace WIDESEAWCS_Tasks; /// /// Quartz 作业日志帮助类 - 统一封装 ILogger 和 QuartzLogger 的双通道日志记录 /// /// /// 所有 Quartz Job 中需要同时写入 ILogger(Serilog)和 QuartzLogger(文件日志)的场景, /// 统一调用此帮助类的方法,避免重复编写两行日志代码。 /// public static class QuartzLogHelper { /// /// 记录错误日志(带异常对象) /// /// ILogger 实例 /// 异常对象 /// ILogger 的结构化日志模板(支持占位符) /// QuartzLogger 的日志消息 /// 设备编码 /// ILogger 结构化日志的参数 public static void LogError(ILogger logger, Exception ex, string loggerMessage, string quartzMessage, string deviceCode, params object[] args) { logger.LogError(ex, loggerMessage, args); QuartzLogger.Error(quartzMessage, deviceCode, ex); } /// /// 记录错误日志(不带异常对象) /// /// ILogger 实例 /// ILogger 的结构化日志模板(支持占位符) /// QuartzLogger 的日志消息 /// 设备编码 /// ILogger 结构化日志的参数 public static void LogError(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args) { logger.LogError(loggerMessage, args); QuartzLogger.Error(quartzMessage, deviceCode); } /// /// 记录信息日志 /// /// ILogger 实例 /// ILogger 的结构化日志模板(支持占位符) /// QuartzLogger 的日志消息 /// 设备编码 /// ILogger 结构化日志的参数 public static void LogInfo(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args) { logger.LogInformation(loggerMessage, args); QuartzLogger.Info(quartzMessage, deviceCode); } /// /// 记录警告日志 /// /// ILogger 实例 /// ILogger 的结构化日志模板(支持占位符) /// QuartzLogger 的日志消息 /// 设备编码 /// ILogger 结构化日志的参数 public static void LogWarn(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args) { logger.LogWarning(loggerMessage, args); QuartzLogger.Warn(quartzMessage, deviceCode); } /// /// 记录调试日志 /// /// ILogger 实例 /// ILogger 的结构化日志模板(支持占位符) /// QuartzLogger 的日志消息 /// 设备编码 /// ILogger 结构化日志的参数 public static void LogDebug(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args) { logger.LogDebug(loggerMessage, args); QuartzLogger.Debug(quartzMessage, deviceCode); } }