難道說谷歌開始從客戶期待證書的情況下?如果是的話,我們該怎麼辦?
如果我理解你的權利和谷歌真正需要證書,你應該使用cryptoprovider並通過stunnel簽名。
也許你的代碼有問題嗎?此設置適用於我
public HttpClient getNewHttpClient() {
try {
KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
trustStore.load(null, null);
SSLSocketFactory sf = new MySSLSocketFactory(trustStore);
sf.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
HttpParams params = new BasicHttpParams();
HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
HttpProtocolParams.setContentCharset(params, HTTP.UTF_8);
SchemeRegistry registry = new SchemeRegistry();
registry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
registry.register(new Scheme("https", sf, 443));
ClientConnectionManager ccm = new ThreadSafeClientConnManager(params, registry);
return new DefaultHttpClient(ccm, params);
} catch (Exception e) {
return new DefaultHttpClient();
}
}
您是否嘗試設置'-Djavax.net.debug = ssl'? – Bruno
不,請嘗試! – instanceOfObject
我從瀏覽器嘗試使用與HttpClient相同的代理時收到'ssl_error_rx_record_too_long'。 – instanceOfObject