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.SSLSession;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
/**
* @ClassName TrustAllCerts
* @Description 解决https请求信任证书问题
*/
public class TrustAllCerts implements 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];}
public static SSLSocketFactory createSSLSocketFactory() {
SSLSocketFactory ssfFactory = null;
try {
SSLContext sc = SSLContext.getInstance("TLS");
sc.init(null, new TrustManager[] { new TrustAllCerts() }, new SecureRandom());
ssfFactory = sc.getSocketFactory();
} catch (Exception e) {
}
return ssfFactory;
}
public static class TrustAllHostnameVerifier implements HostnameVerifier {
@Override
public boolean verify(String hostname, SSLSession session) {
return true;
}
}
}
retrofit工具类
public class RetrofitUtil {
private static RetrofitUtil instance;
private final Retrofit retrofit;
//单例模式
public static RetrofitUtil getInstance(){
if (instance == null){
synchronized (RetrofitUtil.class){
if (instance == null){
instance = new RetrofitUtil();
}
}
}
return instance;
}
//网络请求
private RetrofitUtil(){
HttpLoggingInterceptor interceptor = new HttpLoggingInterceptor();
interceptor.setLevel(HttpLoggingInterceptor.Level.BODY);
OkHttpClient okHttpClient = new OkHttpClient
.Builder()
.addInterceptor(interceptor)
//.addInterceptor(new MoreBaseUrlInterceptor())
.addInterceptor(new HandlerUtils())
.addInterceptor(new TokenInterceptor())
.connectTimeout(20000,TimeUnit.SECONDS)
.readTimeout(20000,TimeUnit.MILLISECONDS)
.writeTimeout(20000,TimeUnit.SECONDS)
.retryOnConnectionFailure(true)
//添加这两行代码
.sslSocketFactory(TrustAllCerts.createSSLSocketFactory())
.hostnameVerifier(new TrustAllCerts.TrustAllHostnameVerifier())
.build();
retrofit = new Retrofit.Builder()
.addConverterFactory(GsonConverterFactory.create())
.addCallAdapterFactory(RxJava2CallAdapterFactory.create())
.baseUrl(API.BASE)
.client(okHttpClient)
.build();
}
public <T> T create(final Class<T> service){
return retrofit.create(service);
}
}