All Projects → jeffijoe → httpclientgoodies.net

jeffijoe / httpclientgoodies.net

Licence: other
Useful utilities for the .NET HttpClient.

Programming Languages

C#
18002 projects
Batchfile
5799 projects

HttpClientGoodies.NET

Build status NuGet

A set of useful utilities for the .NET HttpClient.

Installation

Install-Package HttpClientGoodies

What's it for?

These small but useful utilities will make your HttpClient life worth living.

Fastest way to profit

Here's an example of sending JSON content and reading JSON content in the least amount of code possible, while also providing Basic Authentication.

var dataToSend = new Todo {
    Text = 'Install this package'
};

var createdTodo = await RequestBuilder.Post('http://api.todos.com/todos/{id}')
    .BasicAuthentication("username", "password")
    .AddUrlSegment("id", 123)
    .JsonContent(dataToSend)
    .SendAsync()
    .AsJson<Todo>();

Console.WriteLine(createdTodo.Text);

That's cool, what else can it do?

Quite a lot! All methods that build the request are chainable! Let's asume the following for each snippet:

var builder = new RequestBuilder();
  • Headers:

    builder.AddHeader("X-MyHeader", "cool value");
  • Query parameters

    builder.AddQuery("searchText", "how do i get my girlfriend to tape her fingers together like a dinosaur");
  • Base URI + Resource URI separately

    builder.BaseUri("http://todos.com")
           .ResourceUri("api/todos");
  • URL segments

    builder.BaseUri("http://todos.com")
           .ResourceUri("api/todos/{id}")
           .AddUrlSegment("id", 123);
  • Authentication

    builder.Authentication("Basic", "<some base64 here>");
    
    // Basic auth shortcut (will base64 for you!)
    builder.BasicAuthentication("username", "password");
  • Setting content

    builder.Content(new HttpStringContent("hehehe"));
    
    // Want to send JSON?
    builder.Content(new JsonContent(new Todo()));
    
    // Can do you one better!
    builder.JsonContent(new Todo());
  • HTTP method

    builder.Method(HttpMethod.Get);
  • Getting the HttpRequestMessage to send

    var message = builder.ToHttpRequestMessage();
    await someClient.SendAsync(message);
  • Sending the request without manually calling ToHttpRequestMessage

    var response = await builder.SendAsync();
    // if you have a client instance you can pass it in.
    var response = await builder.SendAsync(client);
  • Reading content as JSON

    var response = await builder.SendAsync();
    var todo = await response.Content.ReadAsJsonAsync<Todo>();
    
    // Even better...
    var todo = await builder.SendAsync().AsJson<Todo>();
    
    // Custom settings? No problemo!
    var settings = new JsonSerializerSettings();
    var todo = await response.Content.ReadAsJsonAsync<Todo>(settings);
    var todo = await builder.SendAsync().AsJson<Todo>(settings);
  • Shortcuts for methods

    The following static methods are available: Get, Post, Put, Patch, Delete, Head, Options, Trace.

    var todo = await RequestBuilder
      .Get('http://todos.com/api/todos/123')
      .SendAsync()
      .AsJson<Todo>();

Author

Jeff Hansen - @Jeffijoe

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].