Skip to content
zhenya edited this page Feb 2, 2020 · 11 revisions

NanoHTTP

NanoHTTP is a dead simple, fluent, easy-to-use, lightweight HTTP Client for Java 8.

Overview

Traditionally, if you wanted to do an HTTP call in Java, you had to use the HttpURLConnection class in the java.net package. Unfortunately HttpURLConnection is a low-level API that is unintuitive at best and downright awful at worst. The resulting code is cumbersome and hard to understand. If you’re wondering what a nightmare the API is, see this StackOverflow post.

NanoHTTP is a paper-thin wrapper around HttpURLConnection with a user friendly API. Do yourself a favor and start making HTTP calls like this:

// A simple GET request
final URL resource = ...
try (final HttpResponse response = HttpClient.defaultClient().get(resource).send()){
   final String text = response.getBody().asString();
   ...
}

Goals

  • Easy to use for common cases
  • A simple, concise, and user-friendly API which caters to 90 percent of application needs
  • Java 8 or higher (Java 8 is still the most used version of the JDK)
  • No dependencies (other than the JDK)
  • Support for "Basic" HTTP authentication scheme
  • Transparent GZip/Deflate support for HTTP responses
  • GZip encoding for HTTP PUT and POST requests
  • Support application/x-www-form-urlencoded content
  • Support for multipart/form-data content
  • Intuitive error handling
  • And more...

Non-goals

  • Asynchronous HTTP requests
  • Support for pluggable low-level HTTP transport libraries
  • Object-Mapped (JSON/XML) responses
  • HTTP/2 support

Warnings

At this point the API is not stable and subject to change.

Why another HTTP Client?

It's true that there are more than several HTTP Client libraries flowing around the Java ecosystem. But there are several features that make NanoHTTP unique.

Since NanoHTTP closely matches the behavior of HttpURLConnection, it is ideal for users who are aware of or written code with HttpURLConnection idiosyncrasies in mind. And did I mention zero dependencies?

But if you want something more?

Here are some popular production-grade HTTP Clients:

  • JDK HttpClient: A modern HTTP Client that supports both HTTP/1.1 and HTTP/2, added in Java 11 (as incubator module in Java 9)
  • OkHttp: An HTTP Client for Android, Kotlin, and Java
  • google-http-java-Client: Google HTTP Client Library for Java and Android
  • Unirest for Java: A simplified, lightweight HTTP Client library
  • Jetty HTTP Client: An efficient HTTP Client with a simple API that supports both asynchronous, non-blocking, as well as synchronous, and blocking requests.

What's next?

  • Publish the project on Maven Central
  • Cookie handling
  • This project is sorely lacking tests
    • Add more unit-tests
    • Add more integration-tests (we will need to decide how to mock HTTP responses, for example we may use WireMock
  • Create a Wiki with frequently asked questions, examples, and guides
  • Create a project site on GitHub pages and publish javadocs or link to javadoc.io

Can I help?

Yes! Send me your patches and contributions. I will come up with an Contributor License Agreement.