package com.github.catvod.net; import android.annotation.SuppressLint; import com.github.catvod.crawler.Spider; import java.io.IOException; import java.security.SecureRandom; import java.security.cert.X509Certificate; import java.util.List; import java.util.Map; import java.util.Objects; import java.util.concurrent.TimeUnit; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManager; import javax.net.ssl.X509TrustManager; import okhttp3.Dns; import okhttp3.Headers; import okhttp3.OkHttpClient; import okhttp3.Request; import okhttp3.Response; public class OkHttp { private static final long TIMEOUT = TimeUnit.SECONDS.toMillis(15); public static final String POST = "POST"; public static final String GET = "GET"; private OkHttpClient client; private static class Loader { static volatile OkHttp INSTANCE = new OkHttp(); } private static OkHttp get() { return Loader.INSTANCE; } public static Response newCall(String url) throws IOException { return client().newCall(new Request.Builder().url(url).build()).execute(); } public static String string(String url) { return string(url, null); } public static String string(String url, long timeout) { return string(url, null, null, timeout); } public static String string(String url, Map header) { return string(url, null, header); } public static String string(String url, Map params, Map header) { return new OkRequest(GET, url, params, header).execute(client()).getBody(); } public static String string(String url, Map params, Map header, long timeout) { return new OkRequest(GET, url, params, header).execute(client(timeout)).getBody(); } public static String post(String url, Map params) { return post(url, params, null).getBody(); } public static OkResult post(String url, Map params, Map header) { return new OkRequest(POST, url, params, header).execute(client()); } public static String post(String url, String json) { return post(url, json, null).getBody(); } public static OkResult post(String url, String json, Map header) { return new OkRequest(POST, url, json, header).execute(client()); } public static String getLocation(String url, Map header) throws IOException { return getLocation(client().newBuilder().followRedirects(false).followSslRedirects(false).build().newCall(new Request.Builder().url(url).headers(Headers.of(header)).build()).execute().headers().toMultimap()); } public static String getLocation(Map> headers) { if (headers == null) return null; if (headers.containsKey("location")) return headers.get("location").get(0); if (headers.containsKey("Location")) return headers.get("Location").get(0); return null; } private static OkHttpClient build() { if (get().client != null) return get().client; return get().client = getBuilder().build(); } private static OkHttpClient.Builder getBuilder() { return new OkHttpClient.Builder().dns(safeDns()).connectTimeout(TIMEOUT, TimeUnit.MILLISECONDS).readTimeout(TIMEOUT, TimeUnit.MILLISECONDS).writeTimeout(TIMEOUT, TimeUnit.MILLISECONDS).hostnameVerifier((hostname, session) -> true).sslSocketFactory(getSSLContext().getSocketFactory(), trustAllCertificates()); } private static OkHttpClient client(long timeout) { return client().newBuilder().connectTimeout(timeout, TimeUnit.MILLISECONDS).readTimeout(timeout, TimeUnit.MILLISECONDS).writeTimeout(timeout, TimeUnit.MILLISECONDS).build(); } private static OkHttpClient client() { try { return Objects.requireNonNull(Spider.client()); } catch (Throwable e) { return build(); } } private static Dns safeDns() { try { return Objects.requireNonNull(Spider.safeDns()); } catch (Throwable e) { return Dns.SYSTEM; } } private static SSLContext getSSLContext() { try { SSLContext context = SSLContext.getInstance("TLS"); context.init(null, new TrustManager[]{trustAllCertificates()}, new SecureRandom()); return context; } catch (Throwable e) { return null; } } @SuppressLint({"TrustAllX509TrustManager", "CustomX509TrustManager"}) private static X509TrustManager trustAllCertificates() { return new X509TrustManager() { @Override public void checkClientTrusted(X509Certificate[] chain, String authType) { } @Override public void checkServerTrusted(X509Certificate[] chain, String authType) { } @Override public X509Certificate[] getAcceptedIssuers() { return new X509Certificate[0]; } }; } }