FluentUriBuilder alternatives and similar packages
Based on the "HTTP" category.
Alternatively, view FluentUriBuilder alternatives based on common mentions on social networks and blogs.
-
Refit
The automatic type-safe REST library for .NET Core, Xamarin and .NET. Heavily inspired by Square's Retrofit library, Refit turns your REST API into a live interface. -
Flurl.Http
Fluent URL builder and testable HTTP client for .NET -
WebApiClient
An open source project based on the HttpClient. You only need to define the c# interface and modify the related features to invoke the client library of the remote http interface asynchronously. -
FastEndpoints
A light-weight REST API development framework for ASP.Net 6 and newer. [Moved to: https://github.com/FastEndpoints/Library] -
RestEase
Easy-to-use typesafe REST API client library for .NET Standard 1.1 and .NET Framework 4.5 and higher, which is simple and customisable. Inspired by Refit -
Simple.OData.Client
Multiplatform OData client library -
RestLess
The automatic type-safe-reflectionless REST API client library for .Net Standard -
Apizr
Refit based web api client management, but resilient (retry, connectivity, cache, auth, log, priority, etc...) -
Cashew
A simple and elegant yet powerful HTTP client cache for .NET -
Lib.Net.Http.WebPush
Lib.Net.Http.WebPush is a library which provides a Web Push Protocol based client for Push Service. -
HttpClientGoodies
Useful utilities for the .NET HttpClient. -
Lib.Net.Http.EncryptedContentEncoding
Lib.Net.Http.EncryptedContentEncoding is a library which adds Encrypted Content-Encoding (aes128gcm) support to HttpClient -
Sandwych.JsonRpc
Sandwych.JsonRpc: A JSON-RPC Client For .NET
Static code analysis for 29 languages.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of FluentUriBuilder or a related project?
README
FluentUriBuilder
A safer and more readable way to build URI's in .NET
Quick example
To build this new URI:
ftp://user:[email protected]:888/path/to/file?param1=val1¶m2=a%23value%26with%40weird%3fcharacters#fragment
Write:
var uri = FluentUriBuilder.Create()
.Scheme(UriScheme.Ftp)
.Credentials("user", "password")
.Host("example.com")
.Port(888)
.Path("path/to/file")
.QueryParams(new {
param1 = "val1",
param2 = "a#value&[email protected]?characters"
})
.Fragment("fragment")
.ToString();
Rationale
You often see code that creates URI's using simple string concatenation or format strings:
var valueWithWeirdCharacters = "a#value&[email protected]?characters";
var badUri1 = "http://example.com/path?param1=" + valueWithWeirdCharacters + "¶m2=asdf";
var badUri2 = string.Format("http://example.com/path?param1={0}¶m2=asdf", valueWithWeirdCharacters);
The result is an invalid URI because the value of param1
is not escaped:
"http://example.com/path?param1=a#value&[email protected]?characters¶m2=asdf"
One alternative is to escape each value using Uri.EscapeDataString
:
var correctUri = "http://example.com/path?param1=" +
Uri.EscapeDataString(valueWithWeirdCharacters) +
"¶m2=asdf";
But this quickly gets ugly when you have a lot of arguments, and it is easy to forget.
Enter System.UriBuilder
:
var valueWithWeirdCharacters = "a#value&[email protected]?characters";
var uriBuilder = new UriBuilder("http://example.com/path");
var parameters = HttpUtility.ParseQueryString(string.Empty);
parameters["param1"] = valueWithWeirdCharacters;
parameters["param2"] = "asdf";
uriBuilder.Query = parameters.ToString();
var correctUri = uriBuilder.AbsoluteUri;
This is correct, but also the most complicated and unreadable of all of the above examples.
This is why I created FluentUriBuilder
: to allow creating URI's in a safe and readable way:
var valueWithWeirdCharacters = "a#value&[email protected]?characters";
var uri = FluentUriBuilder
.From("http://example.com/path")
.QueryParam("param1", valueWithWeirdCharacters)
.QueryParam("param2", "asdf")
.ToString();
More Examples
Query parameters can also be specified using an IDictionary<TKey, TValue>
:
var params = new Dictionary<string, string> {
{ "user", "averagejoe236" },
{ "apiKey", "af43af43rcfaf34xqf" }
};
var uri = FluentUriBuilder.Create()
.Scheme(UriScheme.Http)
.Host("facebook.com")
.Path("posts")
.QueryParams(params)
.ToString();
Or one by one, by calling .QueryParam("key", "value")
repeatedly:
var uri = FluentUriBuilder.Create()
.Scheme(UriScheme.Http)
.Host("google.com")
.Path("/")
.QueryParam("q", "FluentUriBuilder")
.QueryParam("source", "hp")
.ToString();
The latter can be used to specify more query parameters with the same name.
To modify an existing URI:
var uri = FluentUriBuilder.From("http://example.com/somepath?foo=bar#baz")
.Port(8080)
.Path("/otherpath")
.RemoveQueryParams()
.RemoveFragment()
.ToUri();
This example returns a System.Uri
instance instead of a string because of the .ToUri()
call at the end.
Framework Support
The project currently supports .NET 2.0+. .NET Core support is planned.