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

在 .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 中,推荐使用中间件来处理异常。
- 使用 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, “全局异常被捕获”);
基本上就这些。根据应用类型选择合适的全局异常处理机制,能显著提升系统的健壮性。不复杂但容易忽略的是:记得测试异常路径,确保日志能正确输出。