com.android.volley.NoConnectionError:javax.net.ssl.SSLHandshakeException:javax.net.ssl.SSLProtocolException:SSL握手已中止:

Dan*_*hel 8 ssl android android-volley

我在我的应用程序中使用Android中的Volley库,当我尝试向我们的服务器发出POST请求时,我收到以下错误:

com.android.volley.NoConnectionError: javax.net.ssl.SSLHandshakeException: javax.net.ssl.SSLProtocolException: SSL handshake aborted: ssl=0x6821edb0: Failure in SSL library, usually a protocol error
error:1407743E:SSL routines:SSL23_GET_SERVER_HELLO:tlsv1 alert inappropriate fallback (external/openssl/ssl/s23_clnt.c:744 0x5f4c0c46:0x00000000)
Run Code Online (Sandbox Code Playgroud)

我们的服务器使用以下SSL证书进行签名:

i:/C=GB/ST=Greater Manchester/L=Salford/O=COMODO CA Limited/CN=COMODO RSA Organization Validation Secure Server CA
1 s:/C=GB/ST=Greater Manchester/L=Salford/O=COMODO CA Limited/CN=COMODO RSA Organization Validation Secure Server CA
i:/C=GB/ST=Greater Manchester/L=Salford/O=COMODO CA Limited/CN=COMODO RSA Certification Authority
 2 s:/C=GB/ST=Greater Manchester/L=Salford/O=COMODO CA Limited/CN=COMODO RSA Certification Authority
i:/C=SE/O=AddTrust AB/OU=AddTrust External TTP Network/CN=AddTrust External CA Root
Run Code Online (Sandbox Code Playgroud)

该证书由openssl描述如下:

New, TLSv1/SSLv3, Cipher is DHE-RSA-AES256-SHA
Run Code Online (Sandbox Code Playgroud)

我检查了Cipher over Android启用的密码,他们说它默认启用.

我已经针对这个问题尝试了以下解决方案,但没有一个解决了它:

对Volley Android网络库的HTTPS支持 - 不工作(也不适合我,因为它不安全)

如何在Android中为HttpsUrlConnection禁用SSLv3? - 我试过这个,错误仍然发生

在项目中使用的Android Api是Android 5.1(API 22).Volley库版本是1.0.15(也尝试使用最新版本,1.0.18,但问题仍然存在).

我尝试过的另一个解决方案是使用与Volley集成的okhttp库,但问题仍然存在.

任何工作的解决方案将非常感谢.

先感谢您!

UPDATE

顺便说一句,我设法从服务器获得支持的密码:

Supported cipher suites (ORDER IS NOT SIGNIFICANT):
  SSLv3
     RSA_WITH_RC4_128_MD5
     RSA_WITH_RC4_128_SHA
     RSA_WITH_IDEA_CBC_SHA
     RSA_WITH_3DES_EDE_CBC_SHA
     DHE_RSA_WITH_3DES_EDE_CBC_SHA
     RSA_WITH_AES_128_CBC_SHA
     DHE_RSA_WITH_AES_128_CBC_SHA
     RSA_WITH_AES_256_CBC_SHA
     DHE_RSA_WITH_AES_256_CBC_SHA
     RSA_WITH_CAMELLIA_128_CBC_SHA
     DHE_RSA_WITH_CAMELLIA_128_CBC_SHA
     RSA_WITH_CAMELLIA_256_CBC_SHA
     DHE_RSA_WITH_CAMELLIA_256_CBC_SHA
     TLS_RSA_WITH_SEED_CBC_SHA
     TLS_DHE_RSA_WITH_SEED_CBC_SHA
  (TLSv1.0: idem)
  (TLSv1.1: idem)
  TLSv1.2
     RSA_WITH_RC4_128_MD5
     RSA_WITH_RC4_128_SHA
     RSA_WITH_IDEA_CBC_SHA
     RSA_WITH_3DES_EDE_CBC_SHA
     DHE_RSA_WITH_3DES_EDE_CBC_SHA
     RSA_WITH_AES_128_CBC_SHA
     DHE_RSA_WITH_AES_128_CBC_SHA
     RSA_WITH_AES_256_CBC_SHA
     DHE_RSA_WITH_AES_256_CBC_SHA
     RSA_WITH_AES_128_CBC_SHA256
     RSA_WITH_AES_256_CBC_SHA256
     RSA_WITH_CAMELLIA_128_CBC_SHA
     DHE_RSA_WITH_CAMELLIA_128_CBC_SHA
     DHE_RSA_WITH_AES_128_CBC_SHA256
     DHE_RSA_WITH_AES_256_CBC_SHA256
     RSA_WITH_CAMELLIA_256_CBC_SHA
     DHE_RSA_WITH_CAMELLIA_256_CBC_SHA
     TLS_RSA_WITH_SEED_CBC_SHA
     TLS_DHE_RSA_WITH_SEED_CBC_SHA
     TLS_RSA_WITH_AES_128_GCM_SHA256
     TLS_RSA_WITH_AES_256_GCM_SHA384
     TLS_DHE_RSA_WITH_AES_128_GCM_SHA256
     TLS_DHE_RSA_WITH_AES_256_GCM_SHA384
Run Code Online (Sandbox Code Playgroud)

根据我的阅读,API LVL 22上的这些密码应该没有问题.

Dan*_*hel 18

我在数小时的互联网和项目代码搜索后发现了这个问题:在项目中我有一个名为的类JsonToPOJORequest<T>,它扩展了Volley类JsonRequest<T>.这是实际为服务器上的每个方法发出请求的类.在稍微分析一下代码之后,我在构造函数中找到了一个方法调用,如下所示:

setRetryPolicy(new DefaultRetryPolicy(3*DefaultRetryPolicy.DEFAULT_TIMEOUT_MS, 0, 0));
Run Code Online (Sandbox Code Playgroud)

其中DefaultRetryPolicy.DEFAULT_TIMEOUT_MS设置为2500毫秒.

由于POST请求包含大量数据,因此发送请求并从服务器接收响应需要更多时间.

看起来Volley没有等到响应就来了并抛出了TimeoutError.因此,请求已经完成,服务器上的一切顺利,但客户端(Android)不等待服务器并出现错误.

解决方案是将Timeout参数设置为更高或0,如下所示:

setRetryPolicy(new DefaultRetryPolicy(5*DefaultRetryPolicy.DEFAULT_TIMEOUT_MS, 0, 0));
setRetryPolicy(new DefaultRetryPolicy(0, 0, 0));
Run Code Online (Sandbox Code Playgroud)

剩下的两个问题是:

1)为什么要求这么长时间? - > 3*2500 = 7500ms是一个很长的时间(超过7秒)来发出请求.这不是服务器问题,因为在iOS上它工作得很好.

2)为什么VolleyError看起来像这样?

com.android.volley.NoConnectionError: javax.net.ssl.SSLHandshakeException: javax.net.ssl.SSLProtocolException: SSL handshake aborted:
Run Code Online (Sandbox Code Playgroud)

应该是TimeoutError而不是NoConnectionError.

你可以在这里找到关于这个bug的更多信息,我还推断出了解决方案: 当有慢速请求时,Android Volley双帖

https://groups.google.com/forum/#!topic/volley-users/8PE9dBbD6iA