2016-04-27 9 views
10

アプリで同期を実行しているときにこのエラーが発生することがあります。主な問題は、同じコードは、Android 6.0.1デバイス上で動作することですが、4.4.2デバイス上で、私はこのエラーを取得しています:javax.net.ssl.SSLException:4.4.2デバイスのピアによって接続が閉じられました(6.0.1で動作)

私は、サーバーからデータを要求することができないんだ
javax.net.ssl.SSLException: Connection closed by peer 
at com.android.org.conscrypt.NativeCrypto.SSL_do_handshake(Native Method) 
at com.android.org.conscrypt.OpenSSLSocketImpl.startHandshake(OpenSSLSocketImpl.java:406) 
at okhttp3.internal.io.RealConnection.connectTls(RealConnection.java:188) 
at okhttp3.internal.io.RealConnection.connectSocket(RealConnection.java:145) 
at okhttp3.internal.io.RealConnection.connect(RealConnection.java:108) 
at okhttp3.internal.http.StreamAllocation.findConnection(StreamAllocation.java:188) 
at okhttp3.internal.http.StreamAllocation.findHealthyConnection(StreamAllocation.java:127) 
at okhttp3.internal.http.StreamAllocation.newStream(StreamAllocation.java:97) 
at okhttp3.internal.http.HttpEngine.connect(HttpEngine.java:289) 
at okhttp3.internal.http.HttpEngine.sendRequest(HttpEngine.java:241) 
at okhttp3.RealCall.getResponse(RealCall.java:240) 
at okhttp3.RealCall$ApplicationInterceptorChain.proceed(RealCall.java:198) 
at okhttp3.logging.HttpLoggingInterceptor.intercept(HttpLoggingInterceptor.java:203) 
at okhttp3.RealCall$ApplicationInterceptorChain.proceed(RealCall.java:187) 
at okhttp3.RealCall.getResponseWithInterceptorChain(RealCall.java:160) 
at okhttp3.RealCall.access$100(RealCall.java:30) 
at okhttp3.RealCall$AsyncCall.execute(RealCall.java:127) 
at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:33) 
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:841) 

さらにデータが必要な場合は、お気軽にお問い合わせください。ありがとう。

+1

http://stackoverflow.com/a/([こちら]提供の答えを見てみましょう:私はここに修正するために必要な

だけの事は、このように、直接TLS 1.2プロトコルを強制することです33567745/3202633)Robertによって – am110787

+0

ありがとう、それは私に解決策を導いた! – robigroza

答えて

4

ここでのキーは、thisリンクに基づいてTLS 1.2プロトコルを強制的に適用することです。

private class NoSSLv3SSLSocket extends DelegateSSLSocket { 

    private NoSSLv3SSLSocket(SSLSocket delegate) { 
     super(delegate); 
    } 

    @Override 
    public void setEnabledProtocols(String[] protocols) { 
     super.setEnabledProtocols(new String[]{"TLSv1.2"}); // force to use only TLSv1.2 here 
    } 
} 
+0

@DavidCheungあなた自身の答えを自由に投稿してください。 – Michael

関連する問題