NLogHelper.cs 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. using NLog;
  2. namespace DigitalManufacturing.Core
  3. {
  4. /// <summary>
  5. /// Nlog日志帮助类
  6. /// </summary>
  7. public class NLogHelper
  8. {
  9. #region 初始化
  10. readonly Logger _logger;
  11. private NLogHelper(Logger logger)
  12. {
  13. this._logger = logger;
  14. }
  15. /// <summary>
  16. /// 自定义Logger,否则用默认的GetCurrentClassLogger
  17. /// </summary>
  18. /// <param name="name"></param>
  19. public NLogHelper(string name) : this(LogManager.GetLogger(name))
  20. {
  21. }
  22. /// <summary>
  23. /// 默认 ${logger} (Default 文件夹下)
  24. /// </summary>
  25. public static NLogHelper Default { get; private set; }
  26. static NLogHelper()
  27. {
  28. Default = new NLogHelper(LogManager.GetCurrentClassLogger());
  29. }
  30. #endregion
  31. /// <summary>
  32. /// 日志写入,默认info等级
  33. /// </summary>
  34. /// <param name="ModuleName">模块名称</param>
  35. /// <param name="Msg">日志内容</param>
  36. /// <param name="TenantId">租户Id</param>
  37. public void WriteLog(string ModuleName, string Msg, string TenantId = "")
  38. {
  39. LogEventInfo logEventInfo = new LogEventInfo();
  40. logEventInfo.Properties["ModuleName"] = ModuleName;
  41. logEventInfo.Properties["Msg"] = Msg;
  42. logEventInfo.Properties["TenantId"] = TenantId;
  43. logEventInfo.Level = LogLevel.Info;
  44. _logger.Log(logEventInfo);
  45. }
  46. /// <summary>
  47. /// 日志写入,自己传日志类别
  48. /// </summary>
  49. /// <param name="ModuleName">模块名称</param>
  50. /// <param name="Msg">日志内容</param>
  51. /// <param name="Level">日志级别</param>
  52. /// <param name="TenantId">租户Id</param>
  53. public void WriteLog(string ModuleName, string Msg, LogLevel Level, string TenantId = "")
  54. {
  55. LogEventInfo logEventInfo = new LogEventInfo();
  56. logEventInfo.Properties["ModuleName"] = ModuleName;
  57. logEventInfo.Properties["Msg"] = Msg;
  58. logEventInfo.Properties["TenantId"] = TenantId;
  59. logEventInfo.Level = Level;
  60. _logger.Log(logEventInfo);
  61. }
  62. }
  63. }