#asp.net-mvc-2 #logging #elmah
#asp.net-mvc-2 #ведение журнала #elmah
Вопрос:
Это кажется достаточно простым. Elmah регистрирует ошибки, я вижу ошибку в файле elmah.axd, затем я хочу перенести данные в новое пользовательское представление.
Я не могу понять, как извлечь страницу сведений из Elma. Пока все, что я смог сделать, это получить ErrorLogEntry, который я хочу, но не могу понять, как получить фактическую ошибку XML / Exception, которую выдает сервер.
Elmah настроен нормально. Но у меня есть:
<customErrors mode="On" defaultRedirect="~/Error/Index">
<error statusCode="404" redirect="~/Error/NotFound"></error>
</customErrors>
Который переходит к моему простому классу ErrorController.cs:
public virtual ActionResult Index( )
{
Exception ex = null;
try
{
Elmah.ErrorLogDataSourceAdapter eldsa = new Elmah.ErrorLogDataSourceAdapter( );
ErrorLogEntry[] errors = eldsa.GetErrors( 0, 1 );
foreach ( ErrorLogEntry ele in errors )
{
ViewData[ "Description" ] = ele.Error.Message "<br />";
ViewData[ "Description" ] = ele.Error.WebHostHtmlMessage "<br />";
Elmah.ErrorLogPageFactory pf = new ErrorLogPageFactory( );
}
}
catch
{
ViewData[ "Description" ] = "An error occurred.";
}
ViewData[ "Title" ] = "Oops. We're sorry. An error occurred and we're on the case.";
//Email.SendException( ex, "Error in PRISM.NET" );
return View( );
}
Возникающая проблема заключается в том, что WebHostHtmlMessage пуст. Поэтому я не могу получить сообщение об исключении.
Я весь день заглядывал в код Elmah и не могу понять, как вручную создать страницу точно так же, как это делает Elmah при вызове elmah.axd.
Ответ №1:
Предполагая, что вы сохраняете данные в таблице по умолчанию ELMAH_Error
SELECT AllXml
FROM ELMAH_Error
Комментарии:
1. Скорее я хочу извлечь данные из класса Elmah, а не делать это старомодным способом.
Ответ №2:
Решение оказалось следующим:
public virtual ActionResult Index( )
{
Exception ex = null;
try
{
Elmah.ErrorLogDataSourceAdapter eldsa = new Elmah.ErrorLogDataSourceAdapter( );
ErrorLogEntry[] errors = eldsa.GetErrors( 0, 1 );
foreach ( ErrorLogEntry ele in errors )
{
ErrorLogEntry thisError = ErrorLog.GetError(ele.Id);
ex = new Exception( thisError.Error.WebHostHtmlMessage );
}
}
catch
{
ViewData[ "Description" ] = "An error occurred.";
}
ViewData[ "Description" ] = "Oops. We're sorry. An error occurred and we're on the case.";
Email.SendException( ex, "Error in PRISM.NET" );
return View( );
}