All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.http.HttpClient Maven / Gradle / Ivy

Go to download

The AWS SDK for Java Mobile - Core module holds the classes that is used by the individual service clients to interact with Amazon Web Services. Users need to depend on aws-java-sdk artifact for accessing individual client classes.

There is a newer version: 2.6.19
Show newest version
/*
 * Copyright 2015-2018 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 *
 *  http://aws.amazon.com/apache2.0
 *
 * or in the "license" file accompanying this file. This file 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 com.amazonaws.http;

import com.amazonaws.AmazonWebServiceRequest;

import org.apache.http.conn.ssl.BrowserCompatHostnameVerifier;

import java.io.IOException;

/**
 * Interface for an HTTP client. Its main responsibility is to execute an
 * {@link HttpRequest} and return a {@link HttpResponse}. There are some
 * requirements for its implementation.
 * 
    *
  • Execute the request without any modification. An {@link HttpRequest} is * converted from an {@link AmazonWebServiceRequest} with signature information. * If modified, the request is likely to be rejected by AWS service.
  • *
  • Disable retry logic and redirect which are handled by the service client * itself.
  • *
  • Enable {@link BrowserCompatHostnameVerifier} so that a wildcard (such as * "*.amazonaws.com") matches all subdomains, including "a.b.amazonaws.com". * This is needed for S3 virtual hosting. See Virtual Hosting of Buckets for more details.
  • *
  • Beware of the Expect 100-continue header. Currently it's only used in S3's * Put Object API. S3 can fail the request with a status code other than 100 * (continue) or 417 (reject) an an error message in the body.
  • *
  • Cache is unnecessary and isn't recommended to implement until it's * supported by AWS service.
  • *
*/ public interface HttpClient { /** * Executes a {@link HttpRequest} and returns a {@link HttpResponse}. * * @param request a HTTP request * @return the response object * @throws IOException in case of a connection problem */ HttpResponse execute(HttpRequest request) throws IOException; /** * Forcefully shutdown this HTTP client and release all underlying * resources. */ void shutdown(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy