DevPick.io

<report best open source project>

okhttp made by square

Square’s meticulous HTTP client for the JVM, Android, and GraalVM.

👨🏻‍💻

Summary

I think it's a good project so I recommend it to you.

OkHttp

See the project website for documentation and APIs.

HTTP is the way modern applications network. It’s how we exchange data & media. Doing HTTP efficiently makes your stuff load faster and saves bandwidth.

OkHttp is an HTTP client that’s efficient by default:

  • HTTP/2 support allows all requests to the same host to share a socket.
  • Connection pooling reduces request latency (if HTTP/2 isn’t available).
  • Transparent GZIP shrinks download sizes.
  • Response caching avoids the network completely for repeat requests.

OkHttp perseveres when the network is troublesome: it will silently recover from common connection problems. If your service has multiple IP addresses, OkHttp will attempt alternate addresses if the first connect fails. This is necessary for IPv4+IPv6 and services hosted in redundant data centers. OkHttp supports modern TLS features (TLS 1.3, ALPN, certificate pinning). It can be configured to fall back for broad connectivity.

Using OkHttp is easy. Its request/response API is designed with fluent builders and immutability. It supports both synchronous blocking calls and async calls with callbacks.

Get a URL

This program downloads a URL and prints its contents as a string. Full source.

OkHttpClient client = new OkHttpClient();

String run(String url) throws IOException {
  Request request = new Request.Builder()
      .url(url)
      .build();

  try (Response response = client.newCall(request).execute()) {
    return response.body().string();
  }
}

Post to a Server

This program posts data to a service. Full source.

public static final MediaType JSON = MediaType.get("application/json");

OkHttpClient client = new OkHttpClient();

String post(String url, String json) throws IOException {
  RequestBody body = RequestBody.create(json, JSON);
  Request request = new Request.Builder()
      .url(url)
      .post(body)
      .build();
  try (Response response = client.newCall(request).execute()) {
    return response.body().string();
  }
}

Further examples are on the OkHttp Recipes page.

Requirements

OkHttp works on Android 5.0+ (API level 21+) and Java 8+.

OkHttp depends on Okio for high-performance I/O and the Kotlin standard library. Both are small libraries with strong backward-compatibility.

We highly recommend you keep OkHttp up-to-date. As with auto-updating web browsers, staying current with HTTPS clients is an important defense against potential security problems. We track the dynamic TLS ecosystem and adjust OkHttp to improve connectivity and security.

OkHttp uses your platform's built-in TLS implementation. On Java platforms OkHttp also supports Conscrypt, which integrates BoringSSL with Java. OkHttp will use Conscrypt if it is the first security provider:

Security.insertProviderAt(Conscrypt.newProvider(), 1);

The OkHttp 3.12.x branch supports Android 2.3+ (API level 9+) and Java 7+. These platforms lack support for TLS 1.2 and should not be used.

Releases

Our change log has release history.

The latest release is available on Maven Central.

implementation("com.squareup.okhttp3:okhttp:4.11.0")

Snapshot builds are available. R8 and ProGuard rules are available.

Also, we have a bill of materials (BOM) available to help you keep OkHttp artifacts up to date and be sure about version compatibility.

    dependencies {
       // define a BOM and its version
       implementation(platform("com.squareup.okhttp3:okhttp-bom:4.11.0"))

       // define any required OkHttp artifacts without version
       implementation("com.squareup.okhttp3:okhttp")
       implementation("com.squareup.okhttp3:logging-interceptor")
    }

MockWebServer

OkHttp includes a library for testing HTTP, HTTPS, and HTTP/2 clients.

The latest release is available on Maven Central.

testImplementation("com.squareup.okhttp3:mockwebserver:4.11.0")

GraalVM Native Image

Building your native images with Graal https://www.graalvm.org/ should work automatically. This is not currently in a final released version, so 5.0.0-alpha.2 should be used. Please report any bugs or workarounds you find.

See the okcurl module for an example build.

$ ./gradlew okcurl:nativeImage
$ ./okcurl/build/graal/okcurl https://httpbin.org/get

License

Copyright 2019 Square, Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Developers

  • developer 15characterlimi

  • developer adriancole

  • developer adrw

  • developer amirlivneh

  • developer artem-zinnatullin

  • developer christiankatzmann

  • developer cketti

  • developer dave-r12

  • developer edenman

  • developer egorand

  • developer ericaschulz

  • developer goooler

  • developer jakewharton

  • developer jawnnypoo

  • developer jeremy-techson

  • developer lingmingyb

  • developer mescortes

  • developer monkey-mas

  • developer narayank

  • developer nfuller

  • developer nightlynexus

  • developer oldergod

  • developer pforhan

  • developer renovate[bot]

  • developer shaishavgandhi

  • developer swankjesse

  • developer tanghuaizhe

  • developer tony-root

  • developer yschimke

  • developer zacsweers

Who like it

  • developer 0vertex

  • developer 2simple

  • developer 641i130

  • developer aaaayano206

  • developer aarazbakov

  • developer abneryan

  • developer aixcert

  • developer appfinders

  • developer aspindle

  • developer awardedsheet865

  • developer aysnr68

  • developer bhavgandhi

  • developer bigbigmonste

  • developer blockhead1dlw

  • developer book56

  • developer c-mueller

  • developer cassiuscai

  • developer chaojen

  • developer cinkhangin

  • developer cristian-sknz

  • developer damon-cw

  • developer danielphan2003

  • developer decodetalkers

  • developer developerlogi03

  • developer donsn

  • developer drawmoon

  • developer emptycreeper

  • developer ericmoin

  • developer erosdesire

  • developer fl0o0lf

  • developer frestein

  • developer fudanchii

  • developer greenball233

  • developer grekoskall

  • developer gzwrrr

  • developer hamedaskari

  • developer hidegonsan

  • developer huixingwong

  • developer ihengshuai

  • developer ipsvn

  • developer ja2c86

  • developer jahroch

  • developer jamesr404v2

  • developer jeongshin

  • developer jeretthsantos

  • developer jialifunia

  • developer jiangjun8888

  • developer jiecolo

  • developer jobis-eungi

  • developer k68

  • developer kabachel

  • developer kenny-hui

  • developer lazyiones

  • developer learningprocesss

  • developer liaozhixion

  • developer lincaiqin0605

  • developer linxu1231

  • developer longsv

  • developer lovebingo

  • developer lukadimtrijevic

  • developer lvlinkeji

  • developer maslof

  • developer mayankvadariya

  • developer mjakl

  • developer moguila

  • developer moriort

  • developer morteza-qn

  • developer muradmur

  • developer ninghaohua

  • developer ningning0111

  • developer nljaan

  • developer nooblong

  • developer pyb1430501241

  • developer raining2001

  • developer reddragon300

  • developer rohimsh

  • developer rutvik-panchal-246

  • developer shancheli321

  • developer shivam-ingawale

  • developer sitjac

  • developer st4ycool

  • developer suisbuds

  • developer supanart-ptm

  • developer tanlingxiao

  • developer texa1627

  • developer thai-phan

  • developer tp3c

  • developer userzheng686

  • developer vazgenmartiros-dev

  • developer vitorcezila

  • developer wenlittleoil

  • developer woods-marshes

  • developer xnchung

  • developer xpp0210

  • developer yra-a

  • developer zcwk

  • developer zhengyi21st

  • developer zhongjiahui

  • developer zxiaobin07

  • developer zyoak