Apache HttpClient - Usando Proxy

Um servidor proxy é um servidor intermediário entre o cliente e a Internet. Os servidores proxy oferecem as seguintes funcionalidades básicas -

  • Firewall e filtragem de dados de rede

  • Compartilhamento de conexão de rede

  • Cache de dados

Usando a biblioteca HttpClient, você pode enviar uma solicitação HTTP usando um proxy. Siga as etapas abaixo -

Etapa 1 - Criar um objeto HttpHost

Instancie o HttpHost classe do org.apache.http pacote passando um parâmetro de string que representa o nome do host proxy, (do qual você precisa que as solicitações sejam enviadas) para seu construtor.

//Creating an HttpHost object for proxy
HttpHost proxyHost = new HttpHost("localhost");

Da mesma forma, crie outro objeto HttpHost para representar o host de destino para o qual as solicitações devem ser enviadas.

//Creating an HttpHost object for target
HttpHost targetHost = new HttpHost("google.com");

Etapa 2 - Criar um objeto HttpRoutePlanner

o HttpRoutePlannerinterface calcula uma rota para um host especificado. Crie um objeto desta interface instanciando oDefaultProxyRoutePlannerclasse, uma implementação desta interface. Como um parâmetro para seu construtor, passe o host proxy criado acima -

//creating a RoutePlanner object
HttpRoutePlanner routePlanner = new DefaultProxyRoutePlanner(proxyhost);

Etapa 3 - Definir o planejador de rotas para um construtor de cliente

Usando o custom() método do HttpClients classe, crie um HttpClientBuilder objeto e, para este objeto, defina o planejador de rotas criado acima, usando o setRoutePlanner() método.

//Setting the route planner to the HttpClientBuilder object
HttpClientBuilder clientBuilder = HttpClients.custom();

clientBuilder = clientBuilder.setRoutePlanner(routePlanner);

Etapa 4 - Construir o objeto CloseableHttpClient

Construa o CloseableHttpClient objeto chamando o build() método.

//Building a CloseableHttpClient
CloseableHttpClient httpClient = clientBuilder.build();

Etapa 5 - Criar um objeto HttpGet

Crie uma solicitação HTTP GET instanciando o HttpGet classe.

//Creating an HttpGet object
HttpGet httpGet = new HttpGet("/");

Etapa 6 - Executar a solicitação

Uma das variantes do execute() método aceita um HttpHost e HttpRequestobjeta e executa a solicitação. Execute a solicitação usando este método -

//Executing the Get request
HttpResponse httpResponse = httpclient.execute(targetHost, httpGet);

Exemplo

O exemplo a seguir demonstra como enviar uma solicitação HTTP a um servidor via proxy. Neste exemplo, estamos enviando uma solicitação HTTP GET para google.com via localhost. Imprimimos os cabeçalhos da resposta e o corpo da resposta.

import org.apache.http.Header;
import org.apache.http.HttpEntity;
import org.apache.http.HttpHost;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.conn.routing.HttpRoutePlanner;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.DefaultProxyRoutePlanner;
import org.apache.http.util.EntityUtils;

public class RequestViaProxyExample {

   public static void main(String args[]) throws Exception{
 
      //Creating an HttpHost object for proxy
      HttpHost proxyhost = new HttpHost("localhost");

      //Creating an HttpHost object for target
      HttpHost targethost = new HttpHost("google.com");
 
      //creating a RoutePlanner object
      HttpRoutePlanner routePlanner = new DefaultProxyRoutePlanner(proxyhost);

      //Setting the route planner to the HttpClientBuilder object
      HttpClientBuilder clientBuilder = HttpClients.custom();
      clientBuilder = clientBuilder.setRoutePlanner(routePlanner);

      //Building a CloseableHttpClient
      CloseableHttpClient httpclient = clientBuilder.build();

      //Creating an HttpGet object
      HttpGet httpget = new HttpGet("/");

      //Executing the Get request
      HttpResponse httpresponse = httpclient.execute(targethost, httpget);

      //Printing the status line
      System.out.println(httpresponse.getStatusLine());

      //Printing all the headers of the response
      Header[] headers = httpresponse.getAllHeaders();
 
      for (int i = 0; i < headers.length; i++) {
         System.out.println(headers[i]);
      }
      
      //Printing the body of the response
      HttpEntity entity = httpresponse.getEntity();

      if (entity != null) {
         System.out.println(EntityUtils.toString(entity));
      }
   }
}

Resultado

Ao ser executado, o programa acima gera a seguinte saída -

HTTP/1.1 200 OK
Date: Sun, 23 Dec 2018 10:21:47 GMT
Server: Apache/2.4.9 (Win64) PHP/5.5.13
Last-Modified: Tue, 24 Jun 2014 10:46:24 GMT
ETag: "2e-4fc92abc3c000"
Accept-Ranges: bytes
Content-Length: 46
Content-Type: text/html
<html><body><h1>It works!</h1></body></html>