wanshenmean
10 小时以前 ba9c1994b95624b88ef606ec00394990d8f2009f
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
using Microsoft.Extensions.Logging;
using WIDESEAWCS_Core.LogHelper;
 
namespace WIDESEAWCS_Tasks;
 
/// <summary>
/// Quartz 作业日志帮助类 - 统一封装 ILogger 和 QuartzLogger 的双通道日志记录
/// </summary>
/// <remarks>
/// 所有 Quartz Job 中需要同时写入 ILogger(Serilog)和 QuartzLogger(文件日志)的场景,
/// 统一调用此帮助类的方法,避免重复编写两行日志代码。
/// </remarks>
public static class QuartzLogHelper
{
    /// <summary>
    /// 记录错误日志(带异常对象)
    /// </summary>
    /// <param name="logger">ILogger 实例</param>
    /// <param name="ex">异常对象</param>
    /// <param name="loggerMessage">ILogger 的结构化日志模板(支持占位符)</param>
    /// <param name="quartzMessage">QuartzLogger 的日志消息</param>
    /// <param name="deviceCode">设备编码</param>
    /// <param name="args">ILogger 结构化日志的参数</param>
    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);
    }
 
    /// <summary>
    /// 记录错误日志(不带异常对象)
    /// </summary>
    /// <param name="logger">ILogger 实例</param>
    /// <param name="loggerMessage">ILogger 的结构化日志模板(支持占位符)</param>
    /// <param name="quartzMessage">QuartzLogger 的日志消息</param>
    /// <param name="deviceCode">设备编码</param>
    /// <param name="args">ILogger 结构化日志的参数</param>
    public static void LogError(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args)
    {
        logger.LogError(loggerMessage, args);
        QuartzLogger.Error(quartzMessage, deviceCode);
    }
 
    /// <summary>
    /// 记录信息日志
    /// </summary>
    /// <param name="logger">ILogger 实例</param>
    /// <param name="loggerMessage">ILogger 的结构化日志模板(支持占位符)</param>
    /// <param name="quartzMessage">QuartzLogger 的日志消息</param>
    /// <param name="deviceCode">设备编码</param>
    /// <param name="args">ILogger 结构化日志的参数</param>
    public static void LogInfo(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args)
    {
        logger.LogInformation(loggerMessage, args);
        QuartzLogger.Info(quartzMessage, deviceCode);
    }
 
    /// <summary>
    /// 记录警告日志
    /// </summary>
    /// <param name="logger">ILogger 实例</param>
    /// <param name="loggerMessage">ILogger 的结构化日志模板(支持占位符)</param>
    /// <param name="quartzMessage">QuartzLogger 的日志消息</param>
    /// <param name="deviceCode">设备编码</param>
    /// <param name="args">ILogger 结构化日志的参数</param>
    public static void LogWarn(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args)
    {
        logger.LogWarning(loggerMessage, args);
        QuartzLogger.Warn(quartzMessage, deviceCode);
    }
 
    /// <summary>
    /// 记录调试日志
    /// </summary>
    /// <param name="logger">ILogger 实例</param>
    /// <param name="loggerMessage">ILogger 的结构化日志模板(支持占位符)</param>
    /// <param name="quartzMessage">QuartzLogger 的日志消息</param>
    /// <param name="deviceCode">设备编码</param>
    /// <param name="args">ILogger 结构化日志的参数</param>
    public static void LogDebug(ILogger logger, string loggerMessage, string quartzMessage, string deviceCode, params object[] args)
    {
        logger.LogDebug(loggerMessage, args);
        QuartzLogger.Debug(quartzMessage, deviceCode);
    }
}