I uploaded a new build to play store and my build got rejected. Reasons for rejecting is HostnameVerifier Vulnerability. I check all my code and couldn't find any use of HostnameVerifier or setDefaultHostnameVerifier or setHostnameVerifier.
I am using X509TrustManager but again not using X509HostnameVerifier. Below is the implementation for same.
Is there something i am missing or can get more help on this? Thanks in advance.
if (Build.VERSION.SDK_INT >= 16 && Build.VERSION.SDK_INT < 22)
{
try
{
SSLContext sslContext = SSLContext.getInstance("TLSv1.2");
TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(
TrustManagerFactory.getDefaultAlgorithm());
trustManagerFactory.init((KeyStore) null);
TrustManager[] trustManagers = trustManagerFactory.getTrustManagers();
if (trustManagers.length != 1 || !(trustManagers[0] instanceof X509TrustManager)) {
throw new IllegalStateException("Unexpected default trust managers:"
+ Arrays.toString(trustManagers));
}
X509TrustManager trustManager = (X509TrustManager) trustManagers[0];
sslContext.init(null, new TrustManager[] { trustManager }, null);
client.sslSocketFactory(new Tls12SocketFactory(sslContext.getSocketFactory()), trustManager);
ConnectionSpec cs = new ConnectionSpec.Builder(ConnectionSpec.MODERN_TLS)
.tlsVersions(TlsVersion.TLS_1_2)
.build();
List<ConnectionSpec> specs = new ArrayList<>();
specs.add(cs);
specs.add(ConnectionSpec.COMPATIBLE_TLS);
if (supportClearText)
{
specs.add(ConnectionSpec.CLEARTEXT);
}
client.connectionSpecs(specs);
} catch (Exception exc)
{
Timber.e(exc, "Error while setting TLS 1.2");
}
}