android volley https使用证书,Android volley自签名HTTPS信任锚,用于找不到证书路径

您可以尝试以下示例代码。希望这有帮助!

private TrustManager[] getWrappedTrustManagers(TrustManager[] trustManagers) {

final X509TrustManager originalTrustManager = (X509TrustManager) trustManagers[0];

return new TrustManager[]{

new X509TrustManager() {

public X509Certificate[] getAcceptedIssuers() {

return originalTrustManager.getAcceptedIssuers();

}

public void checkClientTrusted(X509Certificate[] certs, String authType) {

try {

if (certs != null && certs.length > 0){

certs[0].checkValidity();

} else {

originalTrustManager.checkClientTrusted(certs, authType);

}

} catch (CertificateException e) {

Log.w("checkClientTrusted", e.toString());

}

}

public void checkServerTrusted(X509Certificate[] certs, String authType) {

try {

if (certs != null && certs.length > 0){

certs[0].checkValidity();

} else {

originalTrustManager.checkServerTrusted(certs, authType);

}

} catch (CertificateException e) {

Log.w("checkServerTrusted", e.toString());

}

}

}

};

}

private SSLSocketFactory getSSLSocketFactory_Certificate(String keyStoreType, int keystoreResId)

throws CertificateException, KeyStoreException, IOException, NoSuchAlgorithmException, KeyManagementException {

CertificateFactory cf = CertificateFactory.getInstance("X.509");

InputStream caInput = getResources().openRawResource(keystoreResId);

Certificate ca = cf.generateCertificate(caInput);

caInput.close();

if (keyStoreType == null || keyStoreType.length() == 0) {

keyStoreType = KeyStore.getDefaultType();

}

KeyStore keyStore = KeyStore.getInstance(keyStoreType);

keyStore.load(null, null);

keyStore.setCertificateEntry("ca", ca);

String tmfAlgorithm = TrustManagerFactory.getDefaultAlgorithm();

TrustManagerFactory tmf = TrustManagerFactory.getInstance(tmfAlgorithm);

tmf.init(keyStore);

TrustManager[] wrappedTrustManagers = getWrappedTrustManagers(tmf.getTrustManagers());

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

sslContext.init(null, wrappedTrustManagers, null);

return sslContext.getSocketFactory();

}

private SSLSocketFactory getSSLSocketFactory_KeyStore(String keyStoreType, int keystoreResId, String keyPassword)

throws CertificateException, KeyStoreException, IOException, NoSuchAlgorithmException, KeyManagementException {

InputStream caInput = getResources().openRawResource(keystoreResId);

// creating a KeyStore containing trusted CAs

if (keyStoreType == null || keyStoreType.length() == 0) {

keyStoreType = KeyStore.getDefaultType();

}

KeyStore keyStore = KeyStore.getInstance(keyStoreType);

keyStore.load(caInput, keyPassword.toCharArray());

// creating a TrustManager that trusts the CAs in the KeyStore

String tmfAlgorithm = TrustManagerFactory.getDefaultAlgorithm();

TrustManagerFactory tmf = TrustManagerFactory.getInstance(tmfAlgorithm);

tmf.init(keyStore);

TrustManager[] wrappedTrustManagers = getWrappedTrustManagers(tmf.getTrustManagers());

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

sslContext.init(null, wrappedTrustManagers, null);

return sslContext.getSocketFactory();

}

然后拨打其中一个:

SSLSocketFactory sslSocketFactory = getSSLSocketFactory_KeyStore("BKS", R.raw.androidbksv1, "123456789");

SSLSocketFactory sslSocketFactory = getSSLSocketFactory_Certificate("BKS", R.raw.androidbksv1_cert);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值