package com.yeyupiaoling.androidclient;
|
|
import java.security.SecureRandom;
|
import java.security.cert.CertificateException;
|
import java.security.cert.X509Certificate;
|
|
import javax.net.ssl.HostnameVerifier;
|
import javax.net.ssl.SSLContext;
|
import javax.net.ssl.SSLSocketFactory;
|
import javax.net.ssl.TrustManager;
|
import javax.net.ssl.X509TrustManager;
|
|
public class SSLSocketClient {
|
//获取SSLSocketFactory
|
public static SSLSocketFactory getSSLSocketFactory() {
|
try {
|
SSLContext sslContext = SSLContext.getInstance("SSL");
|
sslContext.init(null, getTrustManager(), new SecureRandom());
|
return sslContext.getSocketFactory();
|
} catch (Exception e) {
|
throw new RuntimeException(e);
|
}
|
}
|
|
//获取X509TrustManager
|
public static X509TrustManager getX509TrustManager() {
|
X509TrustManager x509TrustManager = new X509TrustManager() {
|
@Override
|
public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
|
}
|
|
@Override
|
public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
|
}
|
|
@Override
|
public X509Certificate[] getAcceptedIssuers() {
|
return new X509Certificate[0];
|
}
|
};
|
return x509TrustManager;
|
}
|
|
//获取TrustManager
|
private static TrustManager[] getTrustManager() {
|
TrustManager[] trustAllCerts = new TrustManager[]{
|
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[]{};
|
}
|
}
|
};
|
return trustAllCerts;
|
}
|
|
//获取HostnameVerifier
|
public static HostnameVerifier getHostnameVerifier() {
|
HostnameVerifier hostnameVerifier = (s, sslSession) -> true;
|
return hostnameVerifier;
|
}
|
}
|