在 .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);
};
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
if (feature != null)
{
await context.Response.WriteAsync(new
{
error = feature.Error.Message
}.ToString());
}
});
});
4. 使用第三方日志框架集成
结合 Serilog、NLog 或 log4net 可以更高效地记录全局异常。
在异常事件中调用日志组件写入文件或发送到远程服务 包含时间、堆栈、用户信息等上下文数据例如,在 UnhandledException 中添加:
logger.Error(exception, "全局异常被捕获");
基本上就这些。根据应用类型选择合适的全局异常处理机制,能显著提升系统的健壮性。不复杂但容易忽略的是:记得测试异常路径,确保日志能正确输出。
