--- title: HTTP Logging in .NET Core and ASP.NET Core author: jkotalik description: Learn how to log HTTP Requests and Response. monikerRange: '>= aspnetcore-6.0' ms.author: jukotali ms.custom: mvc ms.date: 04/20/2021 no-loc: [Home, Privacy, appsettings.json, "ASP.NET Core Identity", cookie, Cookie, Blazor, "Blazor Server", "Blazor WebAssembly", "Identity", "Let's Encrypt", Razor, SignalR] uid: fundamentals/http-logging/index --- # HTTP Logging in ASP.NET Core HTTP Logging is a middleware that logs information about HTTP requests and HTTP responses. HTTP logging provides logs of: * HTTP request information * Common properties * Headers * Body * HTTP response information HTTP Logging is valuable in several scenarios to: * Record information about incoming requests and responses. * Filter which parts of the request and response are logged. * Filtering which headers to log. HTTP Logging ***can reduce the performance of an app***, especially when logging the request and response bodies. Consider and performance impact when selecting fields to log. Test the performance impact of the selected logging properties. > [!WARNING] > HTTP Logging can potentially log personally identifiable information (PII). Consider the risk and avoid logging sensitive information. ## Enabling HTTP logging HTTP Logging is enabled with `UseHttpLogging`, which adds HTTP logging middleware. [!code-csharp[](samples/6.x/Startup.cs?name=snippet&highlight=3)] By default, HTTP Logging logs common properties such as path, query, status-code, and headers for requests and responses. The output is logged as a single message at `LogLevel.Information`. ![Sample request output](_static/requestlog.png) ## HTTP Logging options To configure the HTTP logging middleware, call `AddHttpLogging` in `ConfigureServices`. [!code-csharp[](samples/6.x/Startup.cs?name=configureservices)] ### `LoggingFields` `HttpLoggingOptions.LoggingFields` is an enum flag that configures specific parts of the request and response to log. `LoggingFields` defaults to `RequestPropertiesAndHeaders | ResponsePropertiesAndHeaders`. [!code-csharp[](samples/6.x/Startup.cs?name=configureservices&highlight=6)] | Flag | Flag for logging the HTTP | Value | | ---- | ----------- | :---: | | None | No logging. | 0x0 | | `RequestPath` | Request Path, which includes both the and . | 0x1 | | `RequestQuery` | Request | 0x2 | | `RequestProtocol` | Request . | 0x4 | | `RequestMethod` | Request . | 0x8 | | `RequestScheme` | Request . | 0x10 | | `ResponseStatusCode` | Response . | 0x20 | | `RequestHeaders` | Request . Request headers are logged as soon as the middleware is invoked. Headers are redacted by default with the character '[Redacted]' unless specified in the `HttpLoggingOptions.RequestHeaders`. | 0x40 | | `ResponseHeaders` | Response . Response headers are logged when the is written to or when is called. Headers are redacted by default with the character '[Redacted]' unless specified in the `HttpLoggingOptions.ResponseHeaders`. | 0x80 | | `RequestTrailers` | Request [IHttpRequestTrailersFeature.Trailers](xref:Microsoft.AspNetCore.Http.Features.IHttpRequestTrailersFeature.Trailers) Request Trailers are currently not logged. | 0x100 | | `ResponseTrailers` | Response [IHttpResponseTrailersFeature.Trailers](xref:Microsoft.AspNetCore.Http.Features.IHttpResponseTrailersFeature.Trailers). Response Trailers are currently not logged. | 0x200 | | `RequestBody` | Request .Logging the request body has performance implications, as it requires buffering the entire request body up to `HttpLoggingOptions.RequestBodyLogLimit`. | 0x400 | | `ResponseBody` | Response . Logging the response body has performance implications, as it requires buffering the entire response body up to `HttpLoggingOptions.ResponseBodyLogLimit`. | 0x800 | | `RequestProperties` | Flag for logging a collection of HTTP Request properties, including `RequestPath`, `RequestQuery`, `RequestProtocol`, `RequestMethod`, and `RequestScheme`. | `RequestPath | RequestQuery | RequestProtocol | RequestMethod | RequestScheme` | | `RequestPropertiesAndHeaders` | Flag for logging HTTP Request properties and headers. Includes `RequestProperties` and `RequestHeaders`. | `RequestProperties | RequestHeaders` | | `ResponsePropertiesAndHeaders` | Flag for logging HTTP Response properties and headers. Includes `ResponseStatusCode` and `ResponseHeaders`. | `ResponseStatusCode | ResponseHeaders` | | `Request` | Flag for logging the entire HTTP Request. Includes `RequestPropertiesAndHeaders` and `RequestBody`. Logging the request body has performance implications, as it requires buffering the entire request body up to `HttpLoggingOptions.RequestBodyLogLimit`. | `RequestPropertiesAndHeaders | RequestBody` | | `Response` | Flag for logging the entire HTTP Response. Includes `ResponsePropertiesAndHeaders` and `ResponseBody`. Logging the response body has performance implications, as it requires buffering the entire response body up to `HttpLoggingOptions.ResponseBodyLogLimit`. | `ResponseStatusCode | ResponseHeaders | ResponseBody` | | `All` | Flag for logging both the HTTP Request and Response. Includes `Request` and `Response`. Logging the request and response body has performance implications, as it requires buffering the entire request and response body up to the `HttpLoggingOptions.RequestBodyLogLimit` and `HttpLoggingOptions.ResponseBodyLogLimit`. | `Request | Response` | ### `RequestHeaders` `RequestHeaders` are a set of HTTP Request Headers that are allowed to be logged. Header values are only logged for header names that are in this collection. [!code-csharp[](samples/6.x/Startup.cs?name=configureservices&highlight=7)] ### `ResponseHeaders` `ResponseHeaders` are a set of HTTP Response Headers that are allowed to be logged. Header values are only logged for header names that are in this collection. [!code-csharp[](samples/6.x/Startup.cs?name=configureservices&highlight=8)] ### `MediaTypeOptions` `MediaTypeOptions` provides configuration for selecting which encoding to use for a specific media type. [!code-csharp[](samples/6.x/Startup.cs?name=configureservices&highlight=9)] #### `MediaTypeOptions` methods * `public void AddText(string contentType, Encoding encoding)` * Adds a contentType to be used for logging as text using UTF-8 encoding. * `public void AddText(string contentType, Encoding encoding)` * Adds a contentType to be used for logging as text using the specified encoding. * `public void AddBinary(MediaTypeHeaderValue mediaType)` * Adds a `MediaTypeHeaderValue` to be used for logging as binary. * `public void AddBinary(string contentType` * Adds a content to be used for logging as text using the specified content type. * `public void Clear()` * Clears all MediaTypes. ### `RequestBodyLogLimit` Maximum request body size to log, in bytes. Defaults to 32 KB. [!code-csharp[](samples/6.x/Startup.cs?name=configureservices&highlight=10)] ### `ResponseBodyLogLimit` Maximum response body size to log, in bytes. Defaults to 32 KB. [!code-csharp[](samples/6.x/Startup.cs?name=configureservices&highlight=11)]