An HTTP+SPDY client for Android and Java applications.
Download the latest JAR or grab via Maven:
<dependency>
<groupId>com.squareup.okhttp</groupId>
<artifactId>okhttp</artifactId>
<version>(insert latest version)</version>
</dependency>
OkHttp uses the platform's ProxySelector. Prior to Android 4.0, ProxySelector
didn't honor
the proxyHost
and proxyPort
system properties for HTTPS connections. Work around this by
specifying the https.proxyHost
and https.proxyPort
system properties when using a proxy with
HTTPS.
OkHttp's test suite creates an in-process HTTPS server. Prior to Android 2.3, SSL server sockets were broken, and so HTTPS tests will time out when run on such devices.
Run OkHttp tests on the desktop with Maven. Running SPDY tests on the desktop uses Jetty-NPN which requires OpenJDK 7+.
mvn clean test
Test on a USB-attached Android using Vogar. Unfortunately dx
requires that you build with
Java 6, otherwise the test class will be silently omitted from the .dex
file.
mvn clean
mvn package -DskipTests
vogar \
--classpath ~/.m2/repository/org/bouncycastle/bcprov-jdk15on/1.47/bcprov-jdk15on-1.47.jar \
--classpath ~/.m2/repository/com/google/mockwebserver/mockwebserver/20130122/mockwebserver-20130122.jar \
--classpath target/okhttp-0.9-SNAPSHOT.jar \
./src/test/java
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.