Ответ 1
Существует два варианта использования ELMAH для исключения исключений в WEB API.
Если вы хотите зафиксировать ошибки, встречающиеся в действиях и контроллерах, т.е. в вашей бизнес-логике вы можете создать ActionFilterAttribute и зарегистрировать эти исключения в ELMAH.
Пример:
public class UnhandledExceptionFilter : ExceptionFilterAttribute {
public override void OnException(HttpActionExecutedContext context) {
Elmah.ErrorLog.GetDefault(HttpContext.Current).Log(new Elmah.Error(context.Exception));
}
}
Затем подключитесь, добавив этот фильтр.
public static class WebApiConfig {
public static void Register(HttpConfiguration config) {
config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{id}",
defaults: new { id = RouteParameter.Optional }
);
config.Filters.Add(new UnhandledExceptionFilter());
}
}
С приведенным выше подходом следующие ошибки не будут обрабатываться:
- Исключения, выведенные из конструкторов контроллера.
- Исключения, выведенные из обработчиков сообщений.
- Исключения, возникающие при маршрутизации.
- Исключения, возникающие при сериализации содержимого ответа
Ссылка: http://blogs.msdn.com/b/webdev/archive/2012/11/16/capturing-unhandled-exceptions-in-asp-net-web-api-s-with-elmah.aspx и http://www.asp.net/web-api/overview/error-handling/web-api-global-error-handling
Чтобы ELMAH регистрировал ошибки WEB API на глобальном уровне, чтобы все 500 ошибок сервера были пойманы, сделайте следующее:
Установить nuget: https://www.nuget.org/packages/Elmah.Contrib.WebApi/
Добавьте ниже в WebApiConfig
public static class WebApiConfig
{
public static void Register(HttpConfiguration config)
{
...
config.Services.Add(typeof(IExceptionLogger), new ElmahExceptionLogger());
...
}
}
И если вы хотите показать пользовательские сообщения об ошибках для ошибок 500 Server, вы можете реализовать новый ExceptionHandler в Web Api (обратите внимание, что ExceptionLogger и ExceptionHandler отличаются.)
class OopsExceptionHandler : ExceptionHandler
{
public override void HandleCore(ExceptionHandlerContext context)
{
context.Result = new TextPlainErrorResult
{
Request = context.ExceptionContext.Request,
Content = "Oops! Sorry! Something went wrong." +
"Please contact [email protected] so we can try to fix it."
};
}
private class TextPlainErrorResult : IHttpActionResult
{
public HttpRequestMessage Request { get; set; }
public string Content { get; set; }
public Task<HttpResponseMessage> ExecuteAsync(CancellationToken cancellationToken)
{
HttpResponseMessage response =
new HttpResponseMessage(HttpStatusCode.InternalServerError);
response.Content = new StringContent(Content);
response.RequestMessage = Request;
return Task.FromResult(response);
}
}
}
Ссылка: http://www.asp.net/web-api/overview/error-handling/web-api-global-error-handling