Android Open Source - android-http Web Client Default Http Client






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, 2013 the diamond:dogs|group
 *//  w  w w . jav  a  2 s .c  o m
 * 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;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.ProtocolException;
import java.net.SocketTimeoutException;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.http.Header;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.HttpVersion;
import org.apache.http.NoHttpResponseException;
import org.apache.http.client.HttpRequestRetryHandler;
import org.apache.http.client.RedirectHandler;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpHead;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.HttpRequestBase;
import org.apache.http.client.params.HttpClientParams;
import org.apache.http.conn.ClientConnectionManager;
import org.apache.http.conn.ConnectTimeoutException;
import org.apache.http.conn.ConnectionPoolTimeoutException;
import org.apache.http.conn.scheme.PlainSocketFactory;
import org.apache.http.conn.scheme.Scheme;
import org.apache.http.conn.scheme.SchemeRegistry;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.impl.conn.tsccm.ThreadSafeClientConnManager;
import org.apache.http.params.BasicHttpParams;
import org.apache.http.params.HttpConnectionParams;
import org.apache.http.params.HttpParams;
import org.apache.http.params.HttpProtocolParams;
import org.apache.http.protocol.HTTP;
import org.apache.http.protocol.HttpContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import android.content.Context;
import android.os.Environment;
import at.diamonddogs.data.adapter.ReplyAdapter;
import at.diamonddogs.data.adapter.ReplyAdapter.Status;
import at.diamonddogs.data.dataobjects.WebReply;
import at.diamonddogs.data.dataobjects.WebRequest.Type;
import at.diamonddogs.exception.WebClientException;
import at.diamonddogs.net.ssl.CustomSSLSocketFactory;
import at.diamonddogs.net.ssl.SSLHelper;

/**
 * This {@link WebClient} will be used on Froyo and below. Please do not use
 * this class directly, use {@link WebClientFactory} instead.
 */
public class WebClientDefaultHttpClient extends WebClient implements HttpRequestRetryHandler, RedirectHandler {

  private static final Logger LOGGER = LoggerFactory.getLogger(WebClientDefaultHttpClient.class.getSimpleName());

  /**
   * The instance of {@link DefaultHttpClient} handling the request
   */
  private DefaultHttpClient httpClient;

  /**
   * Request parameters
   */
  private HttpRequestBase requestBase;

  /**
   * Default {@link WebClient} constructor
   * 
   * @param context
   *            a {@link Context} object
   */
  public WebClientDefaultHttpClient(Context context) {
    super(context);

  }

  @Override
  public ReplyAdapter call() {
    ReplyAdapter listenerReply = null;
    HttpResponse response = null;
    try {
      WebReply reply;

      if (webRequest == null) {
        throw new WebClientException("WebRequest must not be null!");
      }

      if (webRequest.getRequestType() == Type.GET) {
        requestBase = new HttpGet(webRequest.getUrl().toURI());
      } else if (webRequest.getRequestType() == Type.HEAD) {
        requestBase = new HttpHead(webRequest.getUrl().toURI());
      } else if (webRequest.getRequestType() == Type.POST) {
        HttpPost post = new HttpPost(webRequest.getUrl().toURI());

        // we need to remove the content length header, to prevent
        // httpClient.execute(...) from failing
        if (webRequest.getHeader() != null) {
          webRequest.removeHeaderField("Content-Length");
        }

        handlePostParameters(post);

        requestBase = post;
      }

      configureConnection();

      LOGGER.info("Running RequestBase: " + requestBase);
      initHttpClient();
      response = httpClient.execute(requestBase);
      reply = runRequest(response);

      listenerReply = createListenerReply(webRequest, reply, null, Status.OK);
    } catch (Throwable tr) {
      // TODO: passing a null reply will cause an nullpointer when calling
      // cacheObjectToFile
      listenerReply = createListenerReply(webRequest, null, tr, Status.FAILED);
      LOGGER.info("Error running webrequest: " + webRequest.getUrl() + " status: "
          + (response == null ? "" : response.getStatusLine().getStatusCode()), tr);
    }
    if (webClientReplyListener != null) {
      webClientReplyListener.onWebReply(this, listenerReply);
    }
    return listenerReply;
  }

  private void initHttpClient() {
    CustomSSLSocketFactory sslSocketFactory = SSLHelper.getInstance().SSL_FACTORY_APACHE;
    if (sslSocketFactory != null) {
      SchemeRegistry registry = new SchemeRegistry();
      registry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
      registry.register(new Scheme("https", sslSocketFactory, 443));
      HttpParams params = new BasicHttpParams();
      HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
      HttpProtocolParams.setContentCharset(params, HTTP.UTF_8);
      ClientConnectionManager ccm = new ThreadSafeClientConnManager(params, registry);
      httpClient = new DefaultHttpClient(ccm, params);
    } else {
      httpClient = new DefaultHttpClient();
    }
    httpClient.setHttpRequestRetryHandler(this);
    if (followProtocolRedirect) {
      httpClient.setRedirectHandler(this);
    }
  }

  private void handlePostParameters(HttpPost post) throws Throwable {
    HttpEntity entity = webRequest.getHttpEntity();

    if (entity != null) {
      post.setEntity(entity);
    }
  }

  private WebReply runRequest(HttpResponse response) throws IOException {
    int statusCode = response.getStatusLine().getStatusCode();
    WebReply reply = null;

    switch (statusCode) {
    case HttpStatus.SC_PARTIAL_CONTENT:
    case HttpStatus.SC_OK:
      LOGGER.debug("WebRequest OK: " + webRequest);
      publishFileSize(response.getEntity().getContentLength());
      reply = handleResponseOk(response.getEntity().getContent(), statusCode, convertHeaders(response.getAllHeaders()));
      break;
    case HttpStatus.SC_NOT_MODIFIED:
      LOGGER.debug("WebRequest Not modified: " + webRequest);
      reply = handleResponseNotModified(statusCode, convertHeaders(response.getAllHeaders()));
      break;
    case HttpStatus.SC_NO_CONTENT:
      reply = handleResponseOk(null, statusCode, convertHeaders(response.getAllHeaders()));
      break;
    default:
      LOGGER.debug("WebRequest DEFAULT: " + webRequest);
      HttpEntity entity = response.getEntity();
      if (entity != null) {
        reply = handleResponseNotOk(entity.getContent(), statusCode, convertHeaders(response.getAllHeaders()));
      } else {
        reply = handleResponseNotOk(null, statusCode, convertHeaders(response.getAllHeaders()));
      }

      break;
    }
    return reply;
  }

  private void writeErrorLog(InputStream content) {
    try {
      FileOutputStream fos = new FileOutputStream(new File(Environment.getExternalStorageDirectory(), "errorlog.txt"));
      byte[] buffer = new byte[1024];
      int len;
      while ((len = content.read(buffer)) != -1) {
        fos.write(buffer, 0, len);
      }
      fos.flush();
      fos.close();
    } catch (Exception e) {
      LOGGER.error("error writing log", e);
    }

  }

  private Map<String, List<String>> convertHeaders(Header[] headers) {
    HashMap<String, List<String>> ret = new HashMap<String, List<String>>();
    for (Header h : headers) {
      String key = h.getName();
      String value = h.getValue();
      if (ret.containsKey(key)) {
        ret.get(key).add(value);
      } else {
        List<String> values = new ArrayList<String>(10);
        values.add(value);
        ret.put(key, values);
      }
    }
    return ret;
  }

  private void configureConnection() throws ProtocolException {
    HttpParams params = new BasicHttpParams();
    HttpConnectionParams.setConnectionTimeout(params, webRequest.getConnectionTimeout());
    HttpConnectionParams.setSoTimeout(params, webRequest.getReadTimeout());
    HttpClientParams.setRedirecting(params, webRequest.isFollowRedirects());
    requestBase.setParams(params);
    buildHeader();
  }

  @Override
  protected void buildHeader() {
    Map<String, String> header = webRequest.getHeader();
    if (header != null) {
      for (String field : header.keySet()) {
        if (webRequest.isAppendHeader()) {
          requestBase.addHeader(field, header.get(field));
        } else {
          requestBase.setHeader(field, header.get(field));
        }
      }
    }
  }

  @Override
  public boolean retryRequest(IOException exception, int executionCount, HttpContext context) {
    LOGGER.error("executionCount:" + executionCount + " NumberOfRetries: " + webRequest.getNumberOfRetries() + " exception: "
        + exception.toString());
    if (executionCount >= webRequest.getNumberOfRetries()) {
      return false;
    }
    // @formatter:off
    if ((exception instanceof NoHttpResponseException) || (exception instanceof ConnectTimeoutException)
        || (exception instanceof ConnectionPoolTimeoutException) || (exception instanceof SocketTimeoutException)) {
      return true;
    }
    // @formatter:on
    return false;
  }

  @Override
  public URI getLocationURI(HttpResponse response, HttpContext context) throws org.apache.http.ProtocolException {
    Header[] headers = response.getHeaders("location");
    if (headers[0] != null) {
      try {
        LOGGER.error("getLocationURI: " + headers[0].getValue());
        return new URI(headers[0].getValue());
      } catch (URISyntaxException e) {
        LOGGER.error("error parsing url", e);
        return null;
      }
    }
    return null;
  }

  @Override
  public boolean isRedirectRequested(HttpResponse response, HttpContext context) {
    if (!webRequest.isFollowRedirects()) {
      return false;
    }
    int status = response.getStatusLine().getStatusCode();
    LOGGER.debug("isRedirectRequested: " + status);
    if (status == HttpStatus.SC_MOVED_PERMANENTLY || status == HttpStatus.SC_MOVED_TEMPORARILY) {
      return true;
    }
    return false;
  }
}




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