--- uid: web-api/overview/error-handling/exception-handling title: "Exception Handling in ASP.NET Web API | Microsoft Docs" author: MikeWasson description: "" ms.author: aspnetcontent manager: wpickett ms.date: 03/12/2012 ms.topic: article ms.assetid: cbebeb37-2594-41f2-b71a-f4f26520d512 ms.technology: dotnet-webapi ms.prod: .net-framework msc.legacyurl: /web-api/overview/error-handling/exception-handling msc.type: authoredcontent --- Exception Handling in ASP.NET Web API ==================== by [Mike Wasson](https://github.com/MikeWasson) This article describes error and exception handling in ASP.NET Web API. - [HttpResponseException](#httpresponserexception) - [Exception Filters](#exception_filters) - [Registering Exception Filters](#registering_exception_filters) - [HttpError](#httperror) ## HttpResponseException What happens if a Web API controller throws an uncaught exception? By default, most exceptions are translated into an HTTP response with status code 500, Internal Server Error. The **HttpResponseException** type is a special case. This exception returns any HTTP status code that you specify in the exception constructor. For example, the following method returns 404, Not Found, if the *id* parameter is not valid. [!code-csharp[Main](exception-handling/samples/sample1.cs)] For more control over the response, you can also construct the entire response message and include it with the **HttpResponseException:** [!code-csharp[Main](exception-handling/samples/sample2.cs)] ## Exception Filters You can customize how Web API handles exceptions by writing an *exception filter*. An exception filter is executed when a controller method throws any unhandled exception that is *not* an **HttpResponseException** exception. The **HttpResponseException** type is a special case, because it is designed specifically for returning an HTTP response. Exception filters implement the **System.Web.Http.Filters.IExceptionFilter** interface. The simplest way to write an exception filter is to derive from the **System.Web.Http.Filters.ExceptionFilterAttribute** class and override the **OnException** method. > [!NOTE] > Exception filters in ASP.NET Web API are similar to those in ASP.NET MVC. However, they are declared in a separate namespace and function separately. In particular, the **HandleErrorAttribute** class used in MVC does not handle exceptions thrown by Web API controllers. Here is a filter that converts **NotImplementedException** exceptions into HTTP status code 501, Not Implemented: [!code-csharp[Main](exception-handling/samples/sample3.cs)] The **Response** property of the **HttpActionExecutedContext** object contains the HTTP response message that will be sent to the client. ## Registering Exception Filters There are several ways to register a Web API exception filter: - By action - By controller - Globally To apply the filter to a specific action, add the filter as an attribute to the action: [!code-csharp[Main](exception-handling/samples/sample4.cs)] To apply the filter to all of the actions on a controller, add the filter as an attribute to the controller class: [!code-csharp[Main](exception-handling/samples/sample5.cs)] To apply the filter globally to all Web API controllers, add an instance of the filter to the **GlobalConfiguration.Configuration.Filters** collection. Exeption filters in this collection apply to any Web API controller action. [!code-csharp[Main](exception-handling/samples/sample6.cs)] If you use the "ASP.NET MVC 4 Web Application" project template to create your project, put your Web API configuration code inside the `WebApiConfig` class, which is located in the App\_Start folder: [!code-csharp[Main](exception-handling/samples/sample7.cs?highlight=5)] ## HttpError The **HttpError** object provides a consistent way to return error information in the response body. The following example shows how to return HTTP status code 404 (Not Found) with an **HttpError** in the response body. [!code-csharp[Main](exception-handling/samples/sample8.cs)] **CreateErrorResponse** is an extension method defined in the **System.Net.Http.HttpRequestMessageExtensions** class. Internally, **CreateErrorResponse** creates an **HttpError** instance and then creates an **HttpResponseMessage** that contains the **HttpError**. In this example, if the method is successful, it returns the product in the HTTP response. But if the requested product is not found, the HTTP response contains an **HttpError** in the request body. The response might look like the following: [!code-console[Main](exception-handling/samples/sample9.cmd)] Notice that the **HttpError** was serialized to JSON in this example. One advantage of using **HttpError** is that it goes through the same [content-negotiation](../formats-and-model-binding/content-negotiation.md) and serialization process as any other strongly-typed model. ### HttpError and Model Validation For model validation, you can pass the model state to **CreateErrorResponse**, to include the validation errors in the response: [!code-csharp[Main](exception-handling/samples/sample10.cs)] This example might return the following response: [!code-console[Main](exception-handling/samples/sample11.cmd)] For more information about model validation, see [Model Validation in ASP.NET Web API](../formats-and-model-binding/model-validation-in-aspnet-web-api.md). ### Using HttpError with HttpResponseException The previous examples return an **HttpResponseMessage** message from the controller action, but you can also use **HttpResponseException** to return an **HttpError**. This lets you return a strongly-typed model in the normal success case, while still returning **HttpError** if there is an error: [!code-csharp[Main](exception-handling/samples/sample12.cs)]