Android – universal image loader | sslhandshakeexception: handshake failed
I have a listview and some contents in the project (textviews, ImageView...). I am using Nostra's UIL to load images in the project, but some of them cannot be loaded. When I call log. V (string. Valueof (failreason. Getcause()); this is what I get:
11-16 23:52:20.447: V/javax.net.ssl.SSLHandshakeException: Handshake Failed(17467): failz
11-16 23:52:20.657: V/NativeCrypto(17467): SSL handshake aborted: ssl=0x15fd758: Failure in SSL library, usually a protocol error
11-16 23:52:20.657: V/NativeCrypto(17467): error:14077410:SSL routines:SSL23_GET_SERVER_HELLO:sslv3 alert handshake failure (external/openssl/ssl/s23_clnt.c:762 0x4c2ed485:0x00000000)
11-16 23:52:21.207: V/NativeCrypto(17467): SSL handshake aborted: ssl=0x1562468: Failure in SSL library, usually a protocol error
11-16 23:52:21.207: V/NativeCrypto(17467): error:14077410:SSL routines:SSL23_GET_SERVER_HELLO:sslv3 alert handshake failure (external/openssl/ssl/s23_clnt.c:762 0x4c2ed485:0x00000000)
You don't know why this problem occurs or how I can solve it?
This is a sample image and cannot be loaded:
http://bigparty.cz/photos/headlinefoto/13.jpg
(I can attach a log containing the whole error – the error that UIL automatically puts into the log)
resolvent:
If I'm right, you must create a certificate, sign it and include it in your application. Or change the server configuration (further information here)
Otherwise, you can trust every handshake in the application. This is not the best method, but it is very useful in the implementation process
Include this class in the project
public class SSLCertificateHandler {
protected static final String TAG = "NukeSSLCerts";
/**
* Enables https connections
*/
public static void nuke() {
try {
TrustManager[] trustAllCerts = new TrustManager[] { new x509trustmanager() {
public X509Certificate[] getAcceptedIssuers() {
X509Certificate[] myTrustedAnchors = new X509Certificate[0];
return myTrustedAnchors;
}
@Override
public void checkClientTrusted(X509Certificate[] certs, String authType) {
}
@Override
public void checkServerTrusted(X509Certificate[] certs, String authType) {
}
} };
SSLContext sc = SSLContext.getInstance("SSL");
sc.init(null, trustAllCerts, new SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {
@Override
public boolean verify(String arg0, SSLSession arg1) {
return true;
}
});
} catch (Exception e) {
}
}
}
Expand your application and invoke the nuke function in your onCreate.
public class YOURApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
//...
// trust all SSL -> HTTPS connection
SSLCertificateHandler.nuke();
}
I found this code in so, but I can't find the link at present