【问题标题】:Can the ASP.NET Yellow Screen of Death (YSOD) be generated on demand or captured?ASP.NET 黄屏死机 (YSOD) 能否按需生成或捕获?
【发布时间】:2010-10-27 02:10:11
【问题描述】:

我们只想从 Global.asax 错误处理程序中捕获 YSOD 输出以在错误报告电子邮件中使用。有没有办法利用内置的 ysod 生成器?

【问题讨论】:

    标签: asp.net error-reporting error-logging yellow-screen-of-death


    【解决方案1】:

    我会调查ELMAH (Error Logging Modules and Handlers for ASP.NET):

    ELMAH(错误记录模块和 处理程序)是应用程序范围的错误 完整的测井设施 可插拔。可以动态添加 到正在运行的 ASP.NET Web 应用程序, 甚至所有 ASP.NET Web 应用程序 在机器上,无需任何 重新编译或重新部署。

    一旦 ELMAH 被放入 运行 Web 应用程序并配置 适当地,你得到以下 设施不改单 你的代码行:

    • 记录几乎所有未处理的异常。
    • 用于远程查看重新编码异常的整个日志的网页。
    • 一个网页可以远程查看任何登录的人的完整详细信息 例外。
    • 很多情况下可以查看原版黄屏死机 为给定的 ASP.NET 生成的 异常,即使使用 customErrors 模式 已关闭。
    • 每个错误发生时的电子邮件通知。
    • 日志中最近 15 个错误的 RSS 提要。

    【讨论】:

    • 看起来 ELMAH 已移至 GitHub,但(原始)Google 代码存档中没有关于此的信息。
    【解决方案2】:

    是的,有一种方法可以做到这一点。

    在 global.asax 文件的 Application_Error 事件中,将最后一个异常作为 System.HttpUnhandledException 获取。您的代码将如下所示:

    var lastException = Server.GetLastError() as HttpUnhandledException;
    string Ysod = lastException.GetHtmlErrorMessage();
    // your call to emailing routine follows
    

    我同意其他人的cmets。您也可以使用 ELMAH 执行此操作。

    【讨论】:

    • 3 年过去了,谁知道我为什么不想使用 ELMAH,但这确实是我一直在寻找的答案。我猜不想在一个已经充斥着 3rd 方模块的繁忙项目中使用另一个依赖项。
    • 也正是我想要的,我在我的项目中使用 Elmah,但在用户是管理员的情况下,我想显示详细的 YSOD 而不仅仅是友好的错误消息。
    • 我在其他项目中使用了 Elmah,但在这种情况下,我特别想控制错误记录,因为 sh!t 太严重了,即使对于 Elmah 也是如此!这正确回答了最初的问题,并且今天仍然存在 sigh
    【解决方案3】:

    你听说过 ELMAH 吗?它可能会为您提供您真正想要的所有功能...

    这是一篇博客文章,对此进行了一些解释:http://www.hanselman.com/blog/ELMAHErrorLoggingModulesAndHandlersForASPNETAndMVCToo.aspx

    【讨论】:

      【解决方案4】:

      您应该查看ELMAH,它会自动执行您所要求的操作。

      【讨论】:

        【解决方案5】:

        一般来说,您不希望用户体验 YSOD。这是我之前在网络应用程序中添加的内容,用于捕获错误,然后为用户提供更优雅的错误页面......

        protected void Application_Error(object sender, EventArgs e)
        {
            MailMessage msg = new MailMessage();
            HttpContext ctx = HttpContext.Current;
        
            msg.To.Add(new MailAddress("me@me.com"));
            msg.From = new MailAddress("from@me.com");
            msg.Subject = "My app had an issue...";
            msg.Priority = MailPriority.High;
        
            StringBuilder sb = new StringBuilder();
            sb.Append(ctx.Request.Url.ToString() + System.Environment.NewLine);
            sb.Append("Source:" + System.Environment.NewLine + ctx.Server.GetLastError().Source.ToString());
            sb.Append("Message:" + System.Environment.NewLine + ctx.Server.GetLastError().Message.ToString());
            sb.Append("Stack Trace:" + System.Environment.NewLine + ctx.Server.GetLastError().StackTrace.ToString());
            msg.Body = sb.ToString();
        
            //CONFIGURE SMTP OBJECT
            SmtpClient smtp = new SmtpClient("myhost");
        
            //SEND EMAIL
            smtp.Send(msg);
        
            //REDIRECT USER TO ERROR PAGE
            Server.Transfer("~/ErrorPage.aspx");
        }
        

        【讨论】:

          【解决方案6】:

          只要应用程序中发生未处理的异常,就会触发 Global.asax 文件中的 Application_Error 事件。您可以使用 Server.GetLastError() 方法获取上次发生的异常。

          同样,您可以通过在 web.config 文件的 customErrors 部分下的 web.config 中指定它来创建自己的自定义错误页面。通过指定默认文件,您可以在将异常路由到那里时进行任何自定义编码。

          【讨论】:

            猜你喜欢
            • 2011-05-14
            • 2011-01-21
            • 2014-03-12
            • 2011-07-23
            • 2011-01-11
            • 2010-09-06
            • 2012-10-27
            • 1970-01-01
            • 2011-06-24
            相关资源
            最近更新 更多