[Android实例] Android 使用HttpClient访问https

谢奕
2023-12-01
  Android中包含了Apache Jakarta Common 下的子项目 HttpClient 类包的一个子集。因此,在大多数情况下可以按照JVM的方式使用HttpClient,但是在有些情况下,由于Android SDK中未包含某些类,处理的方式就有差别。比如,访问https时安全证书的处理。

       假如我们的需求是自动接受所有安全证书。思路跟以前一样,扩展一个SSLSocketFactory类,并将TrustManager里的方法全部重写成空。

       为了方便使用,我直接在Android的org.apache.http.conn.ssl.SSLSocketFactory源码上扩展。

       主要修改了其默认构造方法,如下:

java代码:
  1. private CustomSSLSocketFactory() throws NoSuchAlgorithmException, KeyManagementException {
  2. super();


  3. // this.sslcontext = null;
  4. // this.socketfactory = HttpsURLConnection.getDefaultSSLSocketFactory();
  5. // this.nameResolver = null;


  6. this.sslcontext = SSLContext.getInstance(TLS);
  7. this.sslcontext.init(null, new TrustManager[]{
  8. new X509TrustManager() {
  9. public java.security.cert.X509Certificate[] getAcceptedIssuers() {
  10. return null;
  11. }
  12. public void checkClientTrusted(
  13. java.security.cert.X509Certificate[] certs, String authType) {
  14. }
  15. public void checkServerTrusted(
  16. java.security.cert.X509Certificate[] certs, String authType) {
  17. }
  18. }
  19. }, new SecureRandom());
  20. this.socketfactory = this.sslcontext.getSocketFactory();
  21. this.nameResolver = null;
  22. }
复制代码

       定义好 SSLSocketFactory之后,再使用它来配置 HttpClient并访问 Https就和以前一样了。
 类似资料: