我必須使用HTTPS向服務器發送POST請求(使用自簽名證書)。這就是我要做的事:定義爲HTTPS和自簽名證書問題
HttpClient httpClient = getHttpClient();
for (int i = 0; i < PARAMS.length && !mHttpPost.isAborted(); ++i) {
mHttpPost.setURI(URI.create(mUri + "/" + PARAMS[i].getPath()));
mHttpPost.setEntity(new UrlEncodedFormEntity(PARAMS[i].getContents(), HTTP.UTF_8));
HttpResponse response = httpClient.execute(mHttpPost);
[...]
}
隨着getHttpClient()如下:
public static DefaultHttpClient getHttpClient() {
DefaultHttpClient client = null;
// Setting up parameters
HttpParams params = new BasicHttpParams();
HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
HttpProtocolParams.setContentCharset(params, "utf-8");
params.setBooleanParameter("http.protocol.expect-continue", false);
// Setting timeout
HttpConnectionParams.setConnectionTimeout(params, TIMEOUT);
HttpConnectionParams.setSoTimeout(params, TIMEOUT);
// Registering schemes for both HTTP and HTTPS
SchemeRegistry registry = new SchemeRegistry();
registry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
final SSLSocketFactory sslSocketFactory = SSLSocketFactory.getSocketFactory();
sslSocketFactory.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
registry.register(new Scheme("https", sslSocketFactory, 443));
// Creating thread safe client connection manager
ThreadSafeClientConnManager manager = new ThreadSafeClientConnManager(params, registry);
// Creating HTTP client
client = new DefaultHttpClient(manager, params);
return client;
}
但我得到一個 「不信任的服務器證書」 異常。我知道關於自簽證書的幾個問題已經發布在這裏,但他們都沒有爲我工作...
有誰知道該怎麼辦?
一些細節:我在模擬器上使用API級別4(Android 1.6)。
嗨,我知道這是一個很久以前職位。但是目前我堅持使用這種HTTPS連接。在我可以通過任何安全的HTTPS站點之前,我需要執行哪些步驟? – 2012-02-29 08:07:18
此解決方案非常危險;您正在拋棄使用HTTPS的安全優勢(您的代碼會盲目地信任錯誤的證書)。 – Brian 2014-01-24 22:31:24