Philiprehberger.HttpDebugHandler 0.2.6

dotnet add package Philiprehberger.HttpDebugHandler --version 0.2.6
                    
NuGet\Install-Package Philiprehberger.HttpDebugHandler -Version 0.2.6
                    
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.6" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Philiprehberger.HttpDebugHandler" Version="0.2.6" />
                    
Directory.Packages.props
<PackageReference Include="Philiprehberger.HttpDebugHandler" />
                    
Project file
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.6
                    
#r "nuget: Philiprehberger.HttpDebugHandler, 0.2.6"
                    
#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.6
                    
#: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.6
                    
Install as a Cake Addin
#tool nuget:?package=Philiprehberger.HttpDebugHandler&version=0.2.6
                    
Install as a Cake Tool

Philiprehberger.HttpDebugHandler

CI NuGet License

DelegatingHandler that logs and times every outgoing HttpClient request.

Installation

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

Development

dotnet build src/Philiprehberger.HttpDebugHandler.csproj --configuration Release

License

MIT

Product 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.

Version Downloads Last Updated
0.2.6 73 3/25/2026
0.2.5 80 3/23/2026
0.2.4 75 3/21/2026
0.2.3 94 3/16/2026
0.2.2 81 3/16/2026
0.2.1 87 3/16/2026
0.2.0 80 3/13/2026
0.1.1 85 3/11/2026
0.1.0 92 3/11/2026