Android Open Source - android-http S S L Helper






From Project

Back to project page android-http.

License

The source code is released under:

Apache License

If you think the Android project android-http listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/*
 * Copyright (C) 2012 the diamond:dogs|group
 */*w ww  .  java  2s. c om*/
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package at.diamonddogs.net.ssl;

import java.io.IOException;
import java.io.InputStream;
import java.net.Socket;
import java.net.UnknownHostException;
import java.security.KeyManagementException;
import java.security.KeyStore;
import java.security.KeyStoreException;
import java.security.NoSuchAlgorithmException;
import java.security.UnrecoverableKeyException;
import java.security.cert.CertificateException;

import javax.net.ssl.SSLContext;
import javax.net.ssl.TrustManager;
import javax.net.ssl.TrustManagerFactory;
import javax.net.ssl.X509TrustManager;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import android.content.Context;
import at.diamonddogs.net.WebClient;
import at.diamonddogs.net.WebClientDefaultHttpClient;
import at.diamonddogs.net.WebClientHttpURLConnection;

/**
 * Enables SSL sockets on all included {@link WebClient}
 * 
 * TODO: save 2 SSL states, one for each {@link WebClient}
 */
public class SSLHelper {

  private static final Logger LOGGER = LoggerFactory.getLogger(SSLHelper.class.getSimpleName());
  private static SSLHelper INSTANCE;
  private SSLState sslState;

  /**
   * Stores the SSL factory for the apache {@link WebClient} ->
   * {@link WebClientDefaultHttpClient}
   */
  public CustomSSLSocketFactory SSL_FACTORY_APACHE = null;

  /**
   * Stores the SSL factory for the Java {@link WebClient} ->
   * {@link WebClientHttpURLConnection}
   */
  public javax.net.ssl.SSLSocketFactory SSL_FACTORY_JAVA = null;

  private SSLHelper() {
  }

  /**
   * Singleton SSLHelper
   * 
   * @return the singleton {@link SSLHelper} instance
   */
  public static SSLHelper getInstance() {

    synchronized (SSLHelper.class) {

      if (INSTANCE == null) {
        INSTANCE = new SSLHelper();
        INSTANCE.sslState = new SSLState();
      }
      return INSTANCE;

    }
  }

  /**
   * Register a keystore with SSL (APACHE && JAVA)
   * 
   * @param c
   *            a {@link Context}
   * @param resourceId
   *            the resource id of the keystore
   * @param password
   *            the password of the keystore
   * @return true on success, false otherwise
   */
  public boolean initAllSSLFactory(Context c, int resourceId, String password) {
    return initSSLFactoryApache(c, resourceId, password) && initSSLFactoryJava(c, resourceId, password);
  }

  public boolean initAllSSLFactoryWithCustomTM(Context c, TrustManager tm) {
    return initSSLFactoryApacheWithCustomTM(c, tm) && initSSLFactoryJavaWithCustomTm(c, tm);
  }

  public boolean initSSLFactoryJavaWithCustomTm(Context c, TrustManager tm) {
    try {
      if (c == null || tm == null) {
        LOGGER.info("No keystore specified, using alltrust");
        makeAllTrustManagerForJava();
        return true;
      } else {
        SSLContext sslCtx = SSLContext.getInstance("TLS");
        sslCtx.init(null, new TrustManager[] { tm }, null);
        SSL_FACTORY_JAVA = sslCtx.getSocketFactory();
        sslState.trustAll = false;
        return true;
      }
    } catch (Throwable tr) {
      LOGGER.warn("Error initializing SSLFactoryJava", tr);
      try {
        makeAllTrustManagerForJava();
        sslState.tr = tr;
        return true;
      } catch (Throwable tr1) {
        sslState.tr1 = tr1;
        sslState.sslOk = false;
        LOGGER.warn("Error trusting all certs, no ssl connection possible", tr);
      }
      return false;
    }
  }

  public boolean initSSLFactoryApacheWithCustomTM(Context c, TrustManager tm) {
    try {
      if (c == null || tm == null) {
        LOGGER.info("No keystore specified, using alltrust");
        makeAllTrustManagerForApache();
        return true;
      } else {
        SSL_FACTORY_APACHE = new CustomSSLSocketFactory(tm);
        sslState.trustAll = false;
        return true;
      }
    } catch (Throwable tr) {
      LOGGER.warn("Error initializing SSLFactoryApache, trusting all certs", tr);
      try {
        makeAllTrustManagerForApache();
        sslState.tr = tr;
        return true;
      } catch (Throwable tr1) {
        sslState.tr1 = tr1;
        sslState.sslOk = false;
        LOGGER.warn("Error trusting all certs, no ssl connection possible", tr);
      }
      return false;
    }
  }

  /**
   * Register a keystore with SSL (APACHE)
   * 
   * @param c
   *            a {@link Context}
   * @param resourceId
   *            the resource id of the keystore
   * @param password
   *            the password of the keystore
   * @return true on success, false otherwise
   */
  public boolean initSSLFactoryApache(Context c, int resourceId, String password) {
    try {
      if (c == null || resourceId == -1 || password == null) {
        LOGGER.info("No keystore specified, using alltrust");
        makeAllTrustManagerForApache();
        return true;
      } else {
        KeyStore store = getKeyStore(c, resourceId, password);

        SSL_FACTORY_APACHE = new CustomSSLSocketFactory(store);
        sslState.trustAll = false;
        return true;
      }
    } catch (Throwable tr) {
      LOGGER.warn("Error initializing SSLFactoryApache, trusting all certs", tr);
      try {
        makeAllTrustManagerForApache();
        sslState.tr = tr;
        return true;
      } catch (Throwable tr1) {
        sslState.tr1 = tr1;
        sslState.sslOk = false;
        LOGGER.warn("Error trusting all certs, no ssl connection possible", tr);
      }
      return false;
    }
  }

  private void makeAllTrustManagerForApache() throws KeyStoreException, NoSuchAlgorithmException, CertificateException, IOException,
      KeyManagementException, UnrecoverableKeyException {
    KeyStore store;
    store = KeyStore.getInstance(KeyStore.getDefaultType());
    store.load(null, null);
    SSL_FACTORY_APACHE = new AllTrustingApacheSSLFactory(null);
  }

  /**
   * Register a keystore with SSL (JAVA)
   * 
   * @param c
   *            a {@link Context}
   * @param resourceId
   *            the resource id of the keystore
   * @param password
   *            the password of the keystore
   * @return true on success, false otherwise
   */
  public boolean initSSLFactoryJava(Context c, int resourceId, String password) {
    try {
      if (c == null || resourceId == -1 || password == null) {
        LOGGER.info("No keystore specified, using alltrust");
        makeAllTrustManagerForJava();
        return true;
      } else {
        KeyStore store = getKeyStore(c, resourceId, password);
        TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
        tmf.init(store);
        SSLContext sslCtx = SSLContext.getInstance("TLS");
        sslCtx.init(null, CustomX509TrustManager.getWrappedTrustmanager(tmf.getTrustManagers()), null);
        SSL_FACTORY_JAVA = sslCtx.getSocketFactory();
        sslState.trustAll = false;
        return true;
      }
    } catch (Throwable tr) {
      LOGGER.warn("Error initializing SSLFactoryJava", tr);
      try {
        makeAllTrustManagerForJava();
        sslState.tr = tr;
        return true;
      } catch (Throwable tr1) {
        sslState.tr1 = tr1;
        sslState.sslOk = false;
        LOGGER.warn("Error trusting all certs, no ssl connection possible", tr);
      }
      return false;
    }
  }

  private void makeAllTrustManagerForJava() throws NoSuchAlgorithmException, KeyManagementException {
    SSLContext sslCtx = SSLContext.getInstance("TLS");
    sslCtx.init(null, getAllTrustingManager(), new java.security.SecureRandom());
    SSL_FACTORY_JAVA = sslCtx.getSocketFactory();
  }

  private TrustManager[] getAllTrustingManager() {
    return new TrustManager[] { new X509TrustManager() {
      @Override
      public java.security.cert.X509Certificate[] getAcceptedIssuers() {
        return null;
      }

      @Override
      public void checkClientTrusted(java.security.cert.X509Certificate[] certs, String authType) {
      }

      @Override
      public void checkServerTrusted(java.security.cert.X509Certificate[] certs, String authType) {
      }
    } };
  }

  private KeyStore getKeyStore(Context c, int resourceId, String password) throws KeyStoreException, NoSuchAlgorithmException,
      CertificateException, IOException {
    KeyStore localTrustStore = KeyStore.getInstance("BKS");
    InputStream in = c.getResources().openRawResource(resourceId);
    localTrustStore.load(in, password.toCharArray());
    return localTrustStore;
  }

  /**
   * Gets the SSL state
   * 
   * @return
   */
  public SSLState getSslState() {
    return sslState;
  }

  /**
   * All trusting SSL factory for APACHE
   */
  public final class AllTrustingApacheSSLFactory extends CustomSSLSocketFactory {
    SSLContext sslContext = SSLContext.getInstance("TLS");

    /**
     * Constructor
     * 
     * @param truststore
     *            the truststore
     * @throws NoSuchAlgorithmException
     * @throws KeyManagementException
     * @throws KeyStoreException
     * @throws UnrecoverableKeyException
     */
    public AllTrustingApacheSSLFactory(KeyStore truststore) throws NoSuchAlgorithmException, KeyManagementException, KeyStoreException,
        UnrecoverableKeyException {
      super(truststore);
      sslContext.init(null, getAllTrustingManager(), null);
    }

    @Override
    public Socket createSocket(Socket socket, String host, int port, boolean autoClose) throws IOException, UnknownHostException {
      return sslContext.getSocketFactory().createSocket(socket, host, port, autoClose);
    }

    @Override
    public Socket createSocket() throws IOException {
      return sslContext.getSocketFactory().createSocket();
    }
  }

  /**
   * SSL State representation
   */
  public static final class SSLState {
    /** exception that made SSL impossible to initialized */
    public Throwable tr;
    /** exception that made SSL impossible to initialized */
    public Throwable tr1;
    /** indicates if we trust all SSL connections */
    public boolean trustAll = true;
    /** has SSL been initialized correctly? */
    public boolean sslOk = true;

    @Override
    public String toString() {
      return "SSLState [tr=" + tr + ", tr1=" + tr1 + ", trustAll=" + trustAll + ", sslOk=" + sslOk + "]";
    }

  }

}




Java Source Code List

at.diamonddogs.android.support.v4.util.LruCache.java
at.diamonddogs.builder.WebRequestBuilderConfiguration.java
at.diamonddogs.builder.WebRequestBuilderDefaultConfig.java
at.diamonddogs.builder.WebRequestBuilder.java
at.diamonddogs.contentprovider.AbstractDefaultContentProvider.java
at.diamonddogs.contentprovider.CacheContentProvider.java
at.diamonddogs.data.adapter.ReplyAdapter.java
at.diamonddogs.data.adapter.database.DataBaseAdapterCacheInformation.java
at.diamonddogs.data.adapter.database.DatabaseAdapter.java
at.diamonddogs.data.adapter.database.Query.java
at.diamonddogs.data.adapter.parcelable.ParcelableAdapterTempFile.java
at.diamonddogs.data.adapter.parcelable.ParcelableAdapterWebReply.java
at.diamonddogs.data.adapter.parcelable.ParcelableAdapterWebRequest.java
at.diamonddogs.data.adapter.parcelable.ParcelableAdapter.java
at.diamonddogs.data.adapter.soap.SoapByteArrayAdapter.java
at.diamonddogs.data.adapter.soap.SoapReplyAdapter.java
at.diamonddogs.data.adapter.soap.SoapRequestAdapter.java
at.diamonddogs.data.dataobjects.CacheInformation.java
at.diamonddogs.data.dataobjects.NonTimeCriticalTaskQueueDefaultConfiguration.java
at.diamonddogs.data.dataobjects.NonTimeCriticalTask.java
at.diamonddogs.data.dataobjects.NonTimeCriticalWebRequest.java
at.diamonddogs.data.dataobjects.Reply.java
at.diamonddogs.data.dataobjects.Request.java
at.diamonddogs.data.dataobjects.SoapReply.java
at.diamonddogs.data.dataobjects.SoapRequest.java
at.diamonddogs.data.dataobjects.TempFile.java
at.diamonddogs.data.dataobjects.WebReply.java
at.diamonddogs.data.dataobjects.WebRequest.java
at.diamonddogs.data.parser.JSONArrayProxy.java
at.diamonddogs.data.parser.JSONObjectProxy.java
at.diamonddogs.data.parser.ParserProxy.java
at.diamonddogs.example.http.activity.CachingExampleActivity.java
at.diamonddogs.example.http.activity.HttpExampleActivity.java
at.diamonddogs.example.http.activity.HttpOrderedAsyncAssisiterExampleActivity.java
at.diamonddogs.example.http.activity.HttpServiceAssisterExampleActivity.java
at.diamonddogs.example.http.activity.ImageLoadingExampleListActivity.java
at.diamonddogs.example.http.activity.NonTimeCriticalExampleActivity.java
at.diamonddogs.example.http.activity.StartActivity.java
at.diamonddogs.example.http.dataobject.Example.java
at.diamonddogs.example.http.dataobject.NonTimeCriticalExampleConfiguration.java
at.diamonddogs.example.http.dataobject.Tripple.java
at.diamonddogs.example.http.dataobject.Weather.java
at.diamonddogs.example.http.dataobject.WebComic.java
at.diamonddogs.example.http.factory.NonTimeCriticalExampleConfigFactory.java
at.diamonddogs.example.http.processor.RssProcessor.java
at.diamonddogs.example.http.processor.WeatherProcessor.java
at.diamonddogs.example.http.processor.WebComicProcessor.java
at.diamonddogs.example.http.view.adapter.ImageLoadingExampleAdapter.java
at.diamonddogs.exception.CacheManagerException.java
at.diamonddogs.exception.DatabaseAdapterException.java
at.diamonddogs.exception.ProcessorExeception.java
at.diamonddogs.exception.ServiceException.java
at.diamonddogs.exception.WebClientException.java
at.diamonddogs.net.WebClientDefaultHttpClient.java
at.diamonddogs.net.WebClientFactory.java
at.diamonddogs.net.WebClientHttpURLConnection.java
at.diamonddogs.net.WebClient.java
at.diamonddogs.net.ssl.CustomSSLSocketFactory.java
at.diamonddogs.net.ssl.CustomX509TrustManager.java
at.diamonddogs.net.ssl.SSLHelper.java
at.diamonddogs.nontimecritical.NonTimeCriticalTaskManager.java
at.diamonddogs.nontimecritical.NonTimeCriticalTaskQueueConfigurationDefaultFactory.java
at.diamonddogs.nontimecritical.NonTimeCriticalTaskQueue.java
at.diamonddogs.service.CacheService.java
at.diamonddogs.service.importservice.GenericImportService.java
at.diamonddogs.service.importservice.ImportServiceContract.java
at.diamonddogs.service.importservice.ImportService.java
at.diamonddogs.service.importservice.OrderedImportServiceContract.java
at.diamonddogs.service.importservice.OrderedImportService.java
at.diamonddogs.service.net.HttpOrderedAsyncAssister.java
at.diamonddogs.service.net.HttpServiceAssister.java
at.diamonddogs.service.net.HttpService.java
at.diamonddogs.service.net.ServiceProcessorIdGenerator.java
at.diamonddogs.service.processor.AdjustableImageProcessor.java
at.diamonddogs.service.processor.DataProcessor.java
at.diamonddogs.service.processor.DummyProcessor.java
at.diamonddogs.service.processor.HeadRequestProcessor.java
at.diamonddogs.service.processor.ImageProcessor.java
at.diamonddogs.service.processor.JSONArrayProcessor.java
at.diamonddogs.service.processor.JSONProcessor.java
at.diamonddogs.service.processor.RawDataProcessor.java
at.diamonddogs.service.processor.ServiceProcessorMessageUtil.java
at.diamonddogs.service.processor.ServiceProcessor.java
at.diamonddogs.service.processor.SoapProcessor.java
at.diamonddogs.service.processor.StreamProcessor.java
at.diamonddogs.service.processor.SynchronousProcessor.java
at.diamonddogs.service.processor.SynchronousXmlProcessorNoDom.java
at.diamonddogs.service.processor.XMLProcessorNoDom.java
at.diamonddogs.service.processor.XMLProcessor.java
at.diamonddogs.service.processor.XMLXPathProcessor.java
at.diamonddogs.util.AndroidUtils.java
at.diamonddogs.util.CacheManager.java
at.diamonddogs.util.ConnectivityHelper.java
at.diamonddogs.util.SoapUtil.java
at.diamonddogs.util.Utils.java
at.diamonddogs.util.WorkerQueue.java
org.apache.commons.codec.CharEncoding.java
org.apache.commons.codec.binary.Hex.java
org.apache.commons.codec.binary.StringUtils.java