Проблема с SSL ниже уровня Api 23

Я использую библиотеку Volley, она отлично работает выше уровня Api 23. Ниже уровня Api 23 иногда успех ответа иногда является ошибкой.

ошибка: com.android.volley.NoConnectionError: java.net.UnknownHostException

Это мой код, в котором я реализовал библиотеку волейбола.

if (Build.VERSION.SDK_INT <= Build.VERSION_CODES.KITKAT) {
            HurlStack stack = null;
            try {
               stack = new HurlStack(null, new TLSSocketFactory());
        } catch (KeyManagementException e) {
            e.printStackTrace();
            Log.d("Your Wrapper Class", "Could not create new stack for TLS v1.2");
            stack = new HurlStack();
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
            Log.d("Your Wrapper Class", "Could not create new stack for TLS v1.2");
            stack = new HurlStack();
        }
        queue = Volley.newRequestQueue(mActivity, stack);
    } else {
        queue = Volley.newRequestQueue(mActivity);
    }

TLSSocketFactory.class - этот класс, который я использовал для ssl.

 private SSLSocketFactory internalSSLSocketFactory;

public TLSSocketFactory() throws KeyManagementException, NoSuchAlgorithmException {
    SSLContext context = SSLContext.getInstance("TLS");
    context.init(null, null, null);
    internalSSLSocketFactory = context.getSocketFactory();
}

@Override
public String[] getDefaultCipherSuites() {
    return internalSSLSocketFactory.getDefaultCipherSuites();
}

@Override
public String[] getSupportedCipherSuites() {
    return internalSSLSocketFactory.getSupportedCipherSuites();
}

@Override
public Socket createSocket(Socket s, String host, int port, boolean autoClose) throws IOException {
    return enableTLSOnSocket(internalSSLSocketFactory.createSocket(s, host, port, autoClose));
}

@Override
public Socket createSocket(String host, int port) throws IOException, UnknownHostException {
    return enableTLSOnSocket(internalSSLSocketFactory.createSocket(host, port));
}

@Override
public Socket createSocket(String host, int port, InetAddress localHost, int localPort) throws IOException, UnknownHostException {
    return enableTLSOnSocket(internalSSLSocketFactory.createSocket(host, port, localHost, localPort));
}

@Override
public Socket createSocket(InetAddress host, int port) throws IOException {
    return enableTLSOnSocket(internalSSLSocketFactory.createSocket(host, port));
}

@Override
public Socket createSocket(InetAddress address, int port, InetAddress localAddress, int localPort) throws IOException {
    return enableTLSOnSocket(internalSSLSocketFactory.createSocket(address, port, localAddress, localPort));
}

private Socket enableTLSOnSocket(Socket socket) {
    if (socket != null && (socket instanceof SSLSocket)) {
        ((SSLSocket)socket).setEnabledProtocols(new String[] {"TLSv1.1", "TLSv1.2"});
    }
    return socket;
}

}

Это длинный выстрел, пробовали ли вы вызвать ProviderInstaller.installIfNeeded (getApplicationContext ()) ;? Это требуется на более старых версиях Android. В нем говорится, что он поддерживает TLSV1.2, но на самом деле это не так, пока вы не подключите более новую версию SSL.

millibit 15.09.2018 14:38

Это исключение не имеет отношения к SSL.

President James K. Polk 15.09.2018 15:04
0
2
43
0

Другие вопросы по теме