android采用Https的解决方案,Android 使用 HTTPS

本文详细介绍了在Android项目中使用HTTPS的配置步骤,包括创建hostnameVerifier、sslSocketFactory,以及如何在Okhttp和Glide中应用这些配置,确保安全地访问HTTPS资源。
摘要由CSDN通过智能技术生成

如果你的项目的网络框架是okhttp,那么使用https还是挺简单的,因为okhttp默认支持HTTPS。传送门

Android 使用 HTTPS 配置的步骤。

step

配置hostnameVerifier

new HostnameVerifier() {

@Override

public boolean verify(String hostname, SSLSession session) {

return true;

}

};

2.step

配置 sslSocketFactory

public static SSLSocketFactory getSslSocketFactory(InputStream[] certificates, InputStream bksFile, String password){

try{

TrustManager[] trustManagers = prepareTrustManager(certificates);

KeyManager[] keyManagers = prepareKeyManager(bksFile, password);

SSLContext sslContext = SSLContext.getInstance("TLS");

TrustManager trustManager = null;

if (trustManagers != null){

trustManager = new MyTrustManager(chooseTrustManager(trustManagers));

} else{

trustManager = new UnSafeTrustManager();

}

sslContext.init(keyManagers, new TrustManager[]{trustManager}, new SecureRandom());

return sslContext.getSocketFactory();

} catch (NoSuchAlgorithmException e){

throw new AssertionError(e);

} catch (KeyManagementException e){

throw new AssertionError(e);

} catch (KeyStoreException e){

throw new AssertionError(e);

}

}

private class UnSafeHostnameVerifier implements HostnameVerifier{

@Override

public boolean verify(String hostname, SSLSession session){

return true;

}

}

private static class UnSafeTrustManager implements X509TrustManager{

@Override

public void checkClientTrusted(X509Certificate[] chain, String authType)throws CertificateException{}<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值