7

aspx.cs 中未处理的错误代码将被 global.asax 中的 Application_Error 处理程序捕获。
我已经在 Application_Error 处理程序中编写了一些代码来记录在 aspx.cs 中发生的此类未处理的错误
但是如果日志本身的代码也失败并生成了异常。(可能是由于 I/O 或文件系统问题)
我应该抛出这样的异常吗?
如果我把它扔掉,哪个事件应该收到这样的异常?
或者如果我写“抛出”语法没有区别?
代码示例如下

protected void Application_Error(object sender, EventArgs e)
{
    try
    {
        // my codes to log exception to Database System here....
    }
    catch(Exception)
    {
        throw;  //Should I write "throw" syntax here ? 
    }
}
4

2 回答 2

5

Application_Error 是您可以记录在线程(目前正在处理您的请求)被中止之前发生的异常的最后一个地方。

你不需要抛出任何异常,因为它会在函数退出后自动抛出。

这是它的合理实现

我认为您最关心的是如果您的故障转移机制失败该怎么办。在这种情况下,它是您的日志记录。这在计算机中是一个更大的问题,但是构建链式故障转移机制通常是浪费时间,因为最终一切都可能失败(对您自己的研究的建议:尽量保持一切无状态)。您最好的选择是拥有一个非常可靠的日志记录机制作为您最后的手段,这将在 99.9% 的时间内成功。不打算讨论如何创建这样的机制(而且自己做也不是一个好主意 - 无论如何都要创建自己的记录器,因为有很多技巧需要知道以确保您的日志记录足够高效且不引人注目)但总的来说,我建议你使用elmah,它可能是目前可用的最好的日志框架,它将为您服务。

对于可能会出现的极少量错误(在现实生活中它们可能不会),我不会为它们失眠。

于 2013-02-22T07:52:35.397 回答
0
  • Server.GetLastException()登录后要扔吗?这取决于该异常的性质和原因。我会在特殊的占位符或弹出窗口中显示它
  • 如果尝试记录该异常发生抛出异常?那么你肯定想吞下它
于 2013-02-22T06:31:32.540 回答