Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/square/okhttp
Square’s meticulous HTTP client for the JVM, Android, and GraalVM.
https://github.com/square/okhttp
android graalvm java kotlin
Last synced: 6 days ago
JSON representation
Square’s meticulous HTTP client for the JVM, Android, and GraalVM.
- Host: GitHub
- URL: https://github.com/square/okhttp
- Owner: square
- License: apache-2.0
- Created: 2012-07-23T13:42:55.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2024-10-28T19:54:14.000Z (3 months ago)
- Last Synced: 2024-10-29T19:14:14.195Z (2 months ago)
- Topics: android, graalvm, java, kotlin
- Language: Kotlin
- Homepage: https://square.github.io/okhttp/
- Size: 52.4 MB
- Stars: 45,835
- Watchers: 1,626
- Forks: 9,161
- Open Issues: 180
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE.txt
- Security: docs/security/security.md
Awesome Lists containing this project
- awesome-android - OkHttp - An HTTP+SPDY client for Android and Java applications. (Libraries / Networking)
- awesome-jvm - okhttp - An HTTP+HTTP/2 client for Android and Java applications. (Network)
- awesome-http - OkHttp - activity/y/square/okhttp) (Programming Languages / Java)
- useful-java-links - Square Okhttp - 2.0) , [![GitHub stars](https://img.shields.io/github/stars/square/okhttp.svg?style=social&label=Star&maxAge=2592000)](https://github.com/square/okhttp). ![business friendly license](https://github.com/Vedenin/useful-java-links/blob/master/img/business-friendly.png?raw=true) (III. Network and Integration / 4. Http and ssh)
- android-awesome-libraries - okhttp - An **HTTP+SPDY** client for Android and Java applications (Uncategorized / Uncategorized)
- awesome-android-libraries - OkHttp
- awesome-android-person - okhttp
- awesome-android - OkHttp - An HTTP+SPDY client for Android and Java applications. (Libraries / Networking)
- awesome - okhttp - An HTTP client for Android, Kotlin, and Java. (Java)
- awesome-android - OkHttp
- awesome-android-libraries - https://github.com/square/okhttp
- awesome-http - okhttp
- StarryDivineSky - square/okhttp
- awesome-list - OkHttp - Square’s meticulous HTTP client for the JVM, Android, and GraalVM. (Containers & Language Extentions & Linting / For Java)
- awesome-android-cn - 官网
- my-awesome - square/okhttp - 12 star:46.0k fork:9.2k Square’s meticulous HTTP client for the JVM, Android, and GraalVM. (Kotlin)
- awesome-android-ui - https://github.com/square/okhttp
- awesome-android-ui - https://github.com/square/okhttp
README
OkHttp
======See the [project website][okhttp] 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.A well behaved user agent
-------------------------OkHttp follows modern HTTP specifications such as
* HTTP/1.1 - [RFC 7231](https://datatracker.ietf.org/doc/html/rfc7231)
* HTTP/2 - [RFC 9113](https://datatracker.ietf.org/doc/html/rfc9113)
* Websockets - [RFC 6455](https://datatracker.ietf.org/doc/html/rfc6455)
* SSE - [Server-sent events](https://html.spec.whatwg.org/multipage/server-sent-events.html#server-sent-events)Where the spec is ambiguous, OkHttp follows modern user agents such as popular Browsers or common HTTP Libraries.
OkHttp is principled and avoids being overly configurable, especially when such configuration is
to workaround a buggy server, test invalid scenarios or that contradict the relevant RFC.
Other HTTP libraries exist that fill that gap allowing extensive customisation including potentially
invalid requests.Example Limitations
* Does not allow GET with a body.
* Cache is not an interface with alternative implementations.Get a URL
---------This program downloads a URL and prints its contents as a string. [Full source][get_example].
```java
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][post_example].
```java
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][recipes].
Requirements
------------OkHttp works on Android 5.0+ (API level 21+) and Java 8+.
OkHttp depends on [Okio][okio] for high-performance I/O and the [Kotlin standard library][kotlin]. 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][tls_history] 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][conscrypt], which integrates [BoringSSL](https://github.com/google/boringssl) with Java. OkHttp will use Conscrypt if it is
the first security provider:```java
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][changelog] has release history.
The latest release is available on [Maven Central](https://search.maven.org/artifact/com.squareup.okhttp3/okhttp/4.12.0/jar).
```kotlin
implementation("com.squareup.okhttp3:okhttp:4.12.0")
```Snapshot builds are [available][snap]. [R8 and ProGuard][r8_proguard] rules are available.
Also, we have a [bill of materials (BOM)][bom] available to help you keep OkHttp artifacts up to date and be sure about version compatibility.
```kotlin
dependencies {
// define a BOM and its version
implementation(platform("com.squareup.okhttp3:okhttp-bom:4.12.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](https://search.maven.org/artifact/com.squareup.okhttp3/mockwebserver/4.12.0/jar).
```kotlin
testImplementation("com.squareup.okhttp3:mockwebserver:4.12.0")
```MockWebServer is used for firstly for internal testing, and for basic testing of apps using OkHttp client.
It is not a full featured HTTP testing library that is developed standalone. It is not being actively developed
for new features. As such you might find your needs outgrow MockWebServer and you may which to use a
more full featured testing library such as [MockServer](https://www.mock-server.com/).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.
```shell
$ ./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 athttp://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.
```[bom]: https://docs.gradle.org/6.2/userguide/platforms.html#sub:bom_import
[changelog]: https://square.github.io/okhttp/changelog/
[conscrypt]: https://github.com/google/conscrypt/
[get_example]: https://raw.github.com/square/okhttp/master/samples/guide/src/main/java/okhttp3/guide/GetExample.java
[kotlin]: https://kotlinlang.org/
[okhttp3_pro]: https://raw.githubusercontent.com/square/okhttp/master/okhttp/src/main/resources/META-INF/proguard/okhttp3.pro
[okhttp_312x]: https://github.com/square/okhttp/tree/okhttp_3.12.x
[okhttp]: https://square.github.io/okhttp/
[okio]: https://github.com/square/okio
[post_example]: https://raw.github.com/square/okhttp/master/samples/guide/src/main/java/okhttp3/guide/PostExample.java
[r8_proguard]: https://square.github.io/okhttp/features/r8_proguard/
[recipes]: https://square.github.io/okhttp/recipes/
[snap]: https://s01.oss.sonatype.org/content/repositories/snapshots/
[tls_history]: https://square.github.io/okhttp/tls_configuration_history/