LogExceptionHandler.cs 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. // 麻省理工学院许可证
  2. //
  3. // 版权所有 (c) 2021-2023 zuohuaijun,大名科技(天津)有限公司 联系电话/微信:18020030720 QQ:515096995
  4. //
  5. // 特此免费授予获得本软件的任何人以处理本软件的权利,但须遵守以下条件:在所有副本或重要部分的软件中必须包括上述版权声明和本许可声明。
  6. //
  7. // 软件按“原样”提供,不提供任何形式的明示或暗示的保证,包括但不限于对适销性、适用性和非侵权的保证。
  8. // 在任何情况下,作者或版权持有人均不对任何索赔、损害或其他责任负责,无论是因合同、侵权或其他方式引起的,与软件或其使用或其他交易有关。
  9. using System.Security.Claims;
  10. namespace Admin.NET.Core.Logging;
  11. /// <summary>
  12. /// 全局异常处理
  13. /// </summary>
  14. public class LogExceptionHandler : IGlobalExceptionHandler, ISingleton
  15. {
  16. private readonly IEventPublisher _eventPublisher;
  17. public LogExceptionHandler(IEventPublisher eventPublisher)
  18. {
  19. _eventPublisher = eventPublisher;
  20. }
  21. public async Task OnExceptionAsync(ExceptionContext context)
  22. {
  23. var sysLogEx = new SysLogEx
  24. {
  25. Account = App.User?.FindFirstValue(ClaimConst.Account),
  26. RealName = App.User?.FindFirstValue(ClaimConst.RealName),
  27. ControllerName = context.Exception.TargetSite.DeclaringType?.FullName,
  28. ActionName = context.Exception.TargetSite.Name,
  29. Exception = $"异常信息:{context.Exception.Message} 异常来源:{context.Exception.Source} 堆栈跟踪:{context.Exception.StackTrace}",
  30. RequestParam = context.Exception.TargetSite.GetParameters().ToString(),
  31. LogDateTime = DateTime.Now
  32. };
  33. await _eventPublisher.PublishAsync(new ChannelEventSource("Add:ExLog", sysLogEx));
  34. await _eventPublisher.PublishAsync("Send:ErrorMail", sysLogEx);
  35. }
  36. }