我正在使用 Apache HttpClient 库来设置 https 连接。不幸的是,Android 给了我一个“不可信的服务器证书”错误。如果我使用手机的浏览器浏览该站点,它会正确验证证书,这让我相信我需要让 HttpClient“知道”手机上的根证书。这是我的 HttpClient 设置代码:
HttpParams params = new BasicHttpParams();
HttpConnectionParams.setConnectionTimeout( params, 20000 );
HttpConnectionParams.setSoTimeout( params, 20000 );
HttpProtocolParams.setVersion( params, HttpVersion.HTTP_1_1);
HttpProtocolParams.setContentCharset( params, HTTP.DEFAULT_CONTENT_CHARSET);
HttpProtocolParams.setUseExpectContinue( params, false);
SchemeRegistry schReg = new SchemeRegistry();
schReg.register( new Scheme( "http", PlainSocketFactory.getSocketFactory(), 80 ) );
schReg.register( new Scheme( "https", SSLSocketFactory.getSocketFactory(), 443 ) );
ClientConnectionManager conMgr = new ThreadSafeClientConnManager( params, schReg );
DefaultHttpClient defaultHttpClient = new DefaultHttpClient( conMgr, params );
return ( defaultHttpClient );
如您所见,我对 SSLSocketFactory 没有做任何特别的事情。如何在不在密钥库中添加自定义证书的情况下使 HttpClient 库验证我的站点?我应该创建一个自定义 SSLSocketFactory 并从 Android 手机加载 cacerts.bks 吗?在那种情况下,我可能会遇到不同手机上密钥库的不同密码的问题?
如果您需要更多信息,请告诉我。这个 SSL 东西对我来说非常困难。