.NET中如何处理和捕获全局异常

针对 .net Framework 应用可通过 appDomain.UnhandledException 捕获未处理异常,用于日志记录但无法阻止程序终止;2. wpf 使用 Application.DispatcherUnhandledException、winForms 使用 Application.ThreadException 处理 ui 线程异常并可阻止崩溃;3. ASP.NET Core 推荐使用 UseExceptionHandler 中间件捕获全局异常并返回统一错误响应;4. 结合 Serilog、NLog 等日志框架可持久化记录异常信息;5. 根据应用类型选择合适机制并测试异常路径以确保日志有效输出。

.NET中如何处理和捕获全局异常

在 .NET 应用程序中,全局异常处理是确保程序稳定性和可维护性的关键部分。通过捕获未被处理的异常,可以避免程序意外崩溃,并记录错误信息以便后续分析。以下是几种常见的全局异常捕获方式,适用于不同类型的 .NET 应用。

1. 使用 AppDomain.UnhandledException(适用于 .NET Framework)

对于传统的 .NET Framework 应用(如控制台、WinForms 或 WPF),可以通过订阅 AppDomain.CurrentDomain.UnhandledException 事件来捕获未处理的异常。

示例代码:

AppDomain.CurrentDomain.UnhandledException += (sender, e) =>
{
    var exception = (Exception)e.ExceptionObject;
    // 记录日志或发送通知
    console.WriteLine($”未处理异常: {exception.Message}”);
    Console.WriteLine(exception.StackTrace);
    // 注意:程序仍会终止
};

注意:该事件无法阻止应用程序退出,仅用于日志记录或资源清理。

2. WPF 和 WinForms 中的 UI 线程异常处理

UI 线程上的异常不会触发 AppDomain 的 UnhandledException,需单独处理。

  • WPF:使用 Application.DispatcherUnhandledException
  • WinForms:使用 Application.ThreadException

WPF 示例:

Application.Current.DispatcherUnhandledException += (sender, e) =>
{
    e.Handled = true; // 阻止程序崩溃
    MessageBox.Show(“发生错误:” + e.Exception.Message);
};

WinForms 示例:

Application.ThreadException += (sender, e) =>
{
    MessageBox.Show(“UI 错误:” + e.Exception.Message);
    e.Handled = true;
};

3. ASP.NET Core 中的全局异常处理

在 ASP.NET Core 中,推荐使用中间件来处理异常。

.NET中如何处理和捕获全局异常

千面视频动捕

千面视频动捕是一个AI视频动捕解决方案,专注于将视频中的人体关节二维信息转化为三维模型动作。

.NET中如何处理和捕获全局异常 27

查看详情 .NET中如何处理和捕获全局异常

  • 使用 UseExceptionHandler 启用异常处理中间件
  • 结合 ILogger 记录详细信息

配置示例(Program.cs 或 Startup.cs):

app.UseExceptionHandler(ErrorApp =>
{
    errorApp.Run(async context =>
    {
        context.Response.StatusCode = 500;
        context.Response.ContentType = “application/json”;
        var feature = context.Features.Get<IExceptionHandlerFeature>();
        if (feature != NULL)
        {
            await context.Response.WriteAsync(new
            {
                error = feature.Error.Message
            }.ToString());
        }
    });
});

4. 使用第三方日志框架集成

结合 Serilog、NLog 或 log4net 可以更高效地记录全局异常。

  • 在异常事件中调用日志组件写入文件或发送到远程服务
  • 包含时间、、用户信息等上下文数据

例如,在 UnhandledException 中添加:
logger.Error(exception, “全局异常被捕获”);

基本上就这些。根据应用类型选择合适的全局异常处理机制,能显著提升系统的健壮性。不复杂但容易忽略的是:记得测试异常路径,确保日志能正确输出。

上一篇
下一篇
text=ZqhQzanResources