Elmah добавить сообщение к ошибке, зарегистрированной по вызову Raise (e)
Я немного смущен тем, как добавить сообщение к ошибке, зарегистрированной программно с помощью ELMAH.
например:
public ActionResult DoSomething(int id)
{
try { ... }
catch (Exception e)
{
// I want to include the 'id' param value here, and maybe some
// other stuff, but how?
ErrorSignal.FromCurrentContext().Raise(e);
}
}
Кажется, все, что может сделать Elmah, это регистрировать необработанное исключение, как я могу также регистрировать собственную информацию об отладке?
Ответы
Ответ 1
Вы можете сбросить новый параметр Исключения оригинала как внутреннего исключения, а ELMAH будет записывать сообщения для обоих:
catch(Exception e)
{
Exception ex = new Exception("ID = 1", e);
ErrorSignal.FromCurrentContext().Raise(ex);
}
покажет
System.Exception: ID = 1 ---> System.NullReferenceException: Object reference not set to an instance of an object.
Ответ 2
Я обнаружил, что я также могу сделать что-то вроде:
Elmah.ErrorSignal.FromCurrentContext().Raise(new NotImplementedException("class FbCallback.Page_Load() Request.Url= " + Request.Url));
Чтобы зарегистрировать собственные сообщения. Затем, когда я просматриваю
http://localhost:5050/elmah.axd
Я вижу свои сообщения как тип NotImplementedException.
Не очень красиво, но работает.