android 获取url内容 5.0,获取javax.net.ssl.SSLHandshakeException:Android 5.0...

在Android 5.0上尝试获取HTTPS URL内容时遇到javax.net.ssl.SSLHandshakeException: Connection closed by peer的问题。错误出现在NativeCrypto.SSL_do_handshake方法中。可能是由于自签名证书、主机名验证或TLS版本不兼容导致。已尝试使用ALLOW_ALL_HOSTNAME_VERIFIER和自定义TrustManager,但问题仍然存在。

首先,我已经搜索了互联网并且已经调试了3天.

这是确切的错误,

javax.net.ssl.SSLHandshakeException: Connection closed by peer

at com.android.org.conscrypt.NativeCrypto.SSL_do_handshake(Native Method)

at com.android.org.conscrypt.OpenSSLSocketImpl.startHandshake(OpenSSLSocketImpl.java:302)

at com.android.okhttp.Connection.upgradeToTls(Connection.java:197)

at com.android.okhttp.Connection.connect(Connection.java:151)

at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:276)

at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:211)

at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:373)

at com.android.okhttp.internal.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:106)

at com.android.okhttp.internal.http.HttpURLConnectionImpl.getOutputStream(HttpURLConnectionImpl.java:208)

at com.android.okhttp.internal.http.DelegatingHttpsURLConnection.getOutputStream(DelegatingHttpsURLConnection.java:218)

at com.android.okhttp.internal.http.HttpsURLConnectionImpl.getOutputStream(HttpsURLConnectionImpl.java:25)

at com.aws.wiremo.common.CommonFunctions.sendRequestEx(CommonFunctions.java:618)

at com.aws.wiremo.common.CommonFunctions.sendRequest(CommonFunctions.java:556)

at com.aws.wiremo.screen.kdo.LoadingScreen$MakeRequest.doInBackground(LoadingScreen.java:146)

at com.aws.wiremo.screen.kdo.LoadingScreen$MakeRequest.doInBackground(LoadingScreen.java:125)

at android.os.AsyncTask$2.call(AsyncTask.java:288)

at java.util.concurrent.FutureTask.run(FutureTask.java:237)

at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)

at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)

at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)

at java.lang.Thread.run(Thread.java:818)

出于保密原因,我无法发布代码.

没有由StackTrace给出的异常引起的,所以我无法真正诊断出问题.

这是我可以分享的一些信息.

>请求被发送到https://[IP_address]:443/

>我正在向特殊硬件(例如控制箱)发送请求.我只能通过POST请求写入和检索数据.

>我在CustomTrustManager的checkServerTrusted方法中收到的证书链具有一个CN,该CN不是IP地址,也不是DNS,更像是一个单词(即CN = commonname).

>我的HostNameVerifier暂时为ALLOW_ALL_HOSTNAME_VERIFIER(我认为这可以解决第三个信息的问题?).

>我正在使用SSLContext.getInstance(“ TLS”),并且我的协议是TLSv1,TLSv1.1和TLSv1.2.

>使用的证书是自签名的.

>在checkServerTrusted方法中,X509Certificate链始终由信任管理器信任(我创建了一个始终信任证书的trustManager).

任何输入将不胜感激.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值