Philiprehberger.HttpDebugHandler
0.2.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package Philiprehberger.HttpDebugHandler --version 0.2.0
NuGet\Install-Package Philiprehberger.HttpDebugHandler -Version 0.2.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Philiprehberger.HttpDebugHandler" Version="0.2.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Philiprehberger.HttpDebugHandler" Version="0.2.0" />
<PackageReference Include="Philiprehberger.HttpDebugHandler" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Philiprehberger.HttpDebugHandler --version 0.2.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Philiprehberger.HttpDebugHandler, 0.2.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Philiprehberger.HttpDebugHandler@0.2.0
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Philiprehberger.HttpDebugHandler&version=0.2.0
#tool nuget:?package=Philiprehberger.HttpDebugHandler&version=0.2.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Philiprehberger.HttpDebugHandler
A DelegatingHandler that logs and times every outgoing HttpClient request.
Install
dotnet add package Philiprehberger.HttpDebugHandler
Usage
using Philiprehberger.HttpDebugHandler;
// Default: writes to Console
var client = new HttpClient(new DebugHandler(new HttpClientHandler()));
// Custom callback
var handler = new DebugHandler(log =>
{
Console.WriteLine($"{log.Method} {log.RequestUri} => {log.StatusCode} in {log.ElapsedMilliseconds} ms");
})
{
InnerHandler = new HttpClientHandler()
};
var client = new HttpClient(handler);
var response = await client.GetAsync("https://example.com");
// Output: GET https://example.com/ => 200 in 142 ms
ASP.NET Core / IHttpClientFactory
builder.Services.AddTransient<DebugHandler>();
builder.Services.AddHttpClient("my-client")
.AddHttpMessageHandler<DebugHandler>();
Body Capture
Enable request and/or response body logging:
var handler = new DebugHandler(log =>
{
Console.WriteLine($"{log.Method} {log.RequestUri} => {log.StatusCode}");
if (log.RequestBody is not null)
Console.WriteLine($" Request body: {log.RequestBody}");
if (log.ResponseBody is not null)
Console.WriteLine($" Response body: {log.ResponseBody}");
})
{
InnerHandler = new HttpClientHandler(),
CaptureRequestBody = true,
CaptureResponseBody = true,
MaxBodyCaptureSize = 4096 // optional, default is 65536 (64 KB)
};
Header Logging
Capture request and response headers:
var handler = new DebugHandler(log =>
{
if (log.RequestHeaders is not null)
foreach (var h in log.RequestHeaders)
Console.WriteLine($" > {h.Key}: {h.Value}");
if (log.ResponseHeaders is not null)
foreach (var h in log.ResponseHeaders)
Console.WriteLine($" < {h.Key}: {h.Value}");
})
{
InnerHandler = new HttpClientHandler(),
CaptureHeaders = true
};
Slow Request Warning
Get notified when a request exceeds a time threshold:
var handler = new DebugHandler(log =>
{
Console.WriteLine($"{log.Method} {log.RequestUri} => {log.StatusCode} in {log.ElapsedMilliseconds} ms");
})
{
InnerHandler = new HttpClientHandler(),
SlowRequestThreshold = TimeSpan.FromSeconds(2),
OnSlowRequest = log =>
Console.WriteLine($"SLOW REQUEST: {log.Method} {log.RequestUri} took {log.ElapsedMilliseconds} ms")
};
API
RequestLog
| Property | Type | Description |
|---|---|---|
Method |
string |
HTTP method (GET, POST, ...) |
RequestUri |
Uri? |
Request URL |
StatusCode |
int |
HTTP response status code |
ElapsedMilliseconds |
long |
Round-trip time in milliseconds |
Timestamp |
DateTimeOffset |
UTC time the request was sent |
RequestBody |
string? |
Request body (when CaptureRequestBody is enabled) |
ResponseBody |
string? |
Response body (when CaptureResponseBody is enabled) |
RequestHeaders |
Dictionary<string, string>? |
Request headers (when CaptureHeaders is enabled) |
ResponseHeaders |
Dictionary<string, string>? |
Response headers (when CaptureHeaders is enabled) |
DebugHandler
| Member | Description |
|---|---|
DebugHandler() |
Writes formatted log lines to Console |
DebugHandler(Action<RequestLog>) |
Invokes the provided callback for every request |
CaptureRequestBody |
bool — capture request body content (default false) |
CaptureResponseBody |
bool — capture response body content (default false) |
CaptureHeaders |
bool — capture request and response headers (default false) |
MaxBodyCaptureSize |
int — max characters to capture per body (default 65536) |
SlowRequestThreshold |
TimeSpan? — threshold for slow request detection |
OnSlowRequest |
Action<RequestLog>? — callback for requests exceeding the threshold |
License
MIT
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.