ApacheHttpClient-クイックガイド

ハイパーテキスト転送プロトコル(HTTP)は、分散型の協調型ハイパーメディア情報システム用のアプリケーションレベルのプロトコルです。これは、1990年以来のワールドワイドウェブ(つまり、インターネット)のデータ通信の基盤です。HTTPは、要求メソッド、エラーコード、およびヘッダーの拡張機能を使用するだけでなく、他の目的にも使用できる汎用のステートレスプロトコルです。

基本的に、HTTPはTCP / IPベースの通信プロトコルであり、ワールドワイドウェブ上でデータ(HTMLファイル、画像ファイル、クエリ結果など)を配信するために使用されます。デフォルトのポートはTCP80ですが、他のポートも使用できます。これは、コンピューターが相互に通信するための標準化された方法を提供します。HTTP仕様は、クライアントの要求データがどのように構築されてサーバーに送信されるか、およびサーバーがこれらの要求にどのように応答するかを定義します。

Httpクライアントとは

Httpクライアントは転送ライブラリであり、クライアント側に常駐し、HTTPメッセージを送受信します。これは、最新のHTTP標準を満たす、最新の機能豊富で効率的な実装を提供します。

クライアントライブラリを使用するこれに加えて、WebブラウザやWebサービスクライアントなどのHTTPベースのアプリケーションを構築できます。

Httpクライアントの機能

以下は、Httpクライアントの主な機能です-

  • HttpClientライブラリは、使用可能なすべてのHTTPメソッドを実装します。

  • HttpClientライブラリは、Secure SocketLayerプロトコルを使用してリクエストを保護するためのAPIを提供します。

  • HttpClientを使用すると、プロキシを使用して接続を確立できます。

  • Basic、Digest、NTLMv1、NTLMv2、NTLM2Sessionなどの認証スキームを使用して接続を認証できます。

  • HttpClientライブラリは、複数のスレッドを介したリクエストの送信をサポートしています。を使用してさまざまなスレッドから確立された複数の接続を管理しますClientConnectionPoolManager

  • Apache HttpClientライブラリを使用して、接続タイムアウトを設定できます。

この章では、EclipseIDEでHttpClientの環境を設定する方法について説明します。インストールを続行する前に、システムにEclipseがすでにインストールされていることを確認してください。そうでない場合は、Eclipseをダウンロードしてインストールします。

Eclipseの詳細については、Eclipseチュートリアルを参照してください。

ステップ1-依存関係JARファイルをダウンロードする

HttpClient(コンポーネント)Webサイトの公式ホームページを開き、ダウンロードページに移動します

次に、の最新の安定バージョンをダウンロードします HttpClient。ここでは、チュートリアル全体を通して、バージョン4.5.6を使用しているため、ファイルをダウンロードします。4.5.6.zip

ダウンロードしたフォルダ内に、という名前のフォルダがあります lib これには、HttpClientと連携するために、プロジェクトのクラスパスに追加される必要なJarファイルが含まれています。

ステップ2-プロジェクトを作成し、ビルドパスを設定します

Eclipseを開き、サンプルプロジェクトを作成します。プロジェクトを右クリックしてオプションを選択しますBuild Path → Configure Build Path 以下に示すように。

の中に Java Build Path のフレーム Libraries タブをクリックします Add External JARs

そして、libフォルダー内のすべてのjarファイルを選択し、をクリックします。 Apply and Close

これで、EclipseでHttpClientライブラリを操作する準備が整いました。

GETメソッドは、指定されたURIを使用して指定されたサーバーから情報を取得するために使用されます。GETを使用するリクエストは、データのみを取得する必要があり、データに他の影響を与えることはありません。

HttpClient APIは、という名前のクラスを提供します HttpGet これはgetrequestメソッドを表します。

以下の手順に従って、HttpClientライブラリを使用してgetリクエストを送信します

ステップ1-HttpClientオブジェクトを作成する

ザ・ createDefault() の方法 HttpClients クラスは CloseableHttpClient オブジェクト、これはの基本実装です HttpClient インターフェース。

このメソッドを使用して、以下に示すようにHttpClientオブジェクトを作成します-

CloseableHttpClient httpclient = HttpClients.createDefault();

ステップ2-HttpGetオブジェクトを作成する

ザ・ HttpGet クラスは、URIを使用して指定されたサーバーの情報を取得するHTTPGET要求を表します。

このクラスをインスタンス化して、HTTPGETリクエストを作成します。このクラスのコンストラクターは、URIを表す文字列値を受け入れます。

HttpGet httpget = new HttpGet("http://www.tutorialspoint.com/");

ステップ3-Getリクエストを実行する

ザ・ execute() の方法 CloseableHttpClient クラスは、HttpUriRequest(インターフェイス)オブジェクト(つまり、HttpGet、HttpPost、HttpPut、HttpHeadなど)を受け入れ、応答オブジェクトを返します。

以下に示すように、このメソッドを使用してリクエストを実行します-

HttpResponse httpresponse = httpclient.execute(httpget);

以下は、HttpClientライブラリを使用したHTTPGETリクエストの実行を示す例です。

import java.util.Scanner;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;

public class HttpGetExample {
 
   public static void main(String args[]) throws Exception{
 
      //Creating a HttpClient object
      CloseableHttpClient httpclient = HttpClients.createDefault();

      //Creating a HttpGet object
      HttpGet httpget = new HttpGet("https://www.tutorialspoint.com/ ");

      //Printing the method used
      System.out.println("Request Type: "+httpget.getMethod());

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

      Scanner sc = new Scanner(httpresponse.getEntity().getContent());

      //Printing the status line
      System.out.println(httpresponse.getStatusLine());
      while(sc.hasNext()) {
         System.out.println(sc.nextLine());
      }
   }
}

出力

上記のプログラムは次の出力を生成します-

Request Type: GET
<!DOCTYPE html>
<!--[if IE 8]><html class = "ie ie8"> <![endif]-->
<!--[if IE 9]><html class = "ie ie9"> <![endif]-->
<!--[if gt IE 9]><!-->
<html lang = "en-US"> <!--<![endif]-->
<head>
<!-- Basic -->
<meta charset = "utf-8">
<title>Parallax Scrolling, Java Cryptography, YAML, Python Data Science, Java
i18n, GitLab, TestRail, VersionOne, DBUtils, Common CLI, Seaborn, Ansible,
LOLCODE, Current Affairs 2018, Apache Commons Collections</title>
<meta name = "Description" content = "Parallax Scrolling, Java Cryptography, YAML,
Python Data Science, Java i18n, GitLab, TestRail, VersionOne, DBUtils, Common
CLI, Seaborn, Ansible, LOLCODE, Current Affairs 2018, Intellij Idea, Apache
Commons Collections, Java 9, GSON, TestLink, Inter Process Communication (IPC),
Logo, PySpark, Google Tag Manager, Free IFSC Code, SAP Workflow"/>
<meta name = "Keywords" content = "Python Data Science, Java i18n, GitLab,
TestRail, VersionOne, DBUtils, Common CLI, Seaborn, Ansible, LOLCODE, Gson,
TestLink, Inter Process Communication (IPC), Logo"/>
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" content = "width = device-width,initial-scale = 1.0,userscalable = yes">
<link href = "https://cdn.muicss.com/mui-0.9.39/extra/mui-rem.min.css"
rel = "stylesheet" type = "text/css" />
<link rel = "stylesheet" href="/questions/css/home.css?v = 3" />
<script src = "/questions/js/jquery.min.js"></script>
<script src = "/questions/js/fontawesome.js"></script>
<script src = "https://cdn.muicss.com/mui-0.9.39/js/mui.min.js"></script>
</head>
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
</script>
</body>
</html>

POSTリクエストは、サーバーにデータを送信するために使用されます。たとえば、HTMLフォームを使用した顧客情報、ファイルのアップロードなど。

HttpClient APIは、という名前のクラスを提供します HttpPost これはPOSTリクエストを表します。

以下の手順に従って、HttpClientライブラリを使用してHTTPPOSTリクエストを送信します。

ステップ1-HttpClientオブジェクトを作成する

ザ・ createDefault() の方法 HttpClients クラスはクラスのオブジェクトを返します CloseableHttpClient、これはの基本実装です HttpClient インターフェース。

このメソッドを使用して、HttpClientオブジェクトを作成します。

CloseableHttpClient httpClient = HttpClients.createDefault();

ステップ2-HttpPostオブジェクトを作成する

ザ・ HttpPost クラスは HTTP POSTリクエスト。これにより、必要なデータが送信され、URIを使用して特定のサーバーの情報が取得されます。

をインスタンス化してこのリクエストを作成します HttpPost クラスを作成し、URIを表す文字列値をパラメーターとしてコンストラクターに渡します。

HttpGet httpGet = new HttpGet("http://www.tutorialspoint.com/");

ステップ3-Getリクエストを実行する

ザ・ execute() CloseableHttpClientオブジェクトのメソッドは、HttpUriRequest(インターフェイス)オブジェクト(つまり、HttpGet、HttpPost、HttpPut、HttpHeadなど)を受け入れ、応答オブジェクトを返します。

HttpResponse httpResponse = httpclient.execute(httpget);

以下は、HttpClientライブラリを使用したHTTPPOSTリクエストの実行を示す例です。

import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;

public class HttpPostExample {
 
   public static void main(String args[]) throws Exception{
 
      //Creating a HttpClient object
      CloseableHttpClient httpclient = HttpClients.createDefault();

      //Creating a HttpGet object
      HttpPost httppost = new HttpPost("https://www.tutorialspoint.com/");

      //Printing the method used
      System.out.println("Request Type: "+httppost.getMethod());

      //Executing the Get request
      HttpResponse httpresponse = httpclient.execute(httppost);

      Scanner sc = new Scanner(httpresponse.getEntity().getContent());

      //Printing the status line
      System.out.println(httpresponse.getStatusLine());
      while(sc.hasNext()) {
         System.out.println(sc.nextLine());
      }
   }
}

出力

上記のプログラムは、次の出力を生成します。

Request Type: POST
<!DOCTYPE html>
<!--[if IE 8]><html class = "ie ie8"> <![endif]-->
<!--[if IE 9]><html class = "ie ie9"> <![endif]-->
<!--[if gt IE 9]><!--> 
<html lang = "en-US"> <!--<![endif]-->
<head>
<!-- Basic -->
<meta charset = "utf-8">
<title>Parallax Scrolling, Java Cryptography, YAML, Python Data Science, Java
i18n, GitLab, TestRail, VersionOne, DBUtils, Common CLI, Seaborn, Ansible,
LOLCODE, Current Affairs 2018, Apache Commons Collections</title>
<meta name = "Description" content = "Parallax Scrolling, Java Cryptography, YAML,
Python Data Science, Java i18n, GitLab, TestRail, VersionOne, DBUtils, Common
CLI, Seaborn, Ansible, LOLCODE, Current Affairs 2018, Intellij Idea, Apache
Commons Collections, Java 9, GSON, TestLink, Inter Process Communication (IPC),
Logo, PySpark, Google Tag Manager, Free IFSC Code, SAP Workflow"/>
<meta name = "Keywords" content="Python Data Science, Java i18n, GitLab,
TestRail, VersionOne, DBUtils, Common CLI, Seaborn, Ansible, LOLCODE, Gson,
TestLink, Inter Process Communication (IPC), Logo"/>
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" conten t= "width = device-width,initial-scale = 1.0,userscalable = yes">
<link href = "https://cdn.muicss.com/mui-0.9.39/extra/mui-rem.min.css"
rel = "stylesheet" type = "text/css" />
<link rel = "stylesheet" href = "/questions/css/home.css?v = 3" />
<script src = "/questions/js/jquery.min.js"></script>
<script src = "/questions/js/fontawesome.js"></script>
<script src = "https://cdn.muicss.com/mui-0.9.39/js/mui.min.js"></script>
</head>
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
</script>
</body>
</html>

応答ハンドラーを使用してHTTP応答を処理することをお勧めします。この章では、応答ハンドラーを作成する方法と、それらを使用して応答を処理する方法について説明します。

応答ハンドラーを使用すると、すべてのHTTP接続が自動的に解放されます。

応答ハンドラーの作成

HttpClient APIは、次のようなインターフェースを提供します。 ResponseHandler パッケージに org.apache.http.client. 応答ハンドラーを作成するには、このインターフェースを実装し、 handleResponse() 方法。

すべての応答にはステータスコードがあり、ステータスコードが200〜300の場合、アクションが正常に受信され、理解され、受け入れられたことを意味します。したがって、この例では、このようなステータスコードを使用して応答のエンティティを処理します。

応答ハンドラーを使用して要求を実行する

以下の手順に従って、応答ハンドラーを使用して要求を実行します。

ステップ1-HttpClientオブジェクトを作成する

ザ・ createDefault() の方法 HttpClients クラスはクラスのオブジェクトを返します CloseableHttpClient、これはの基本実装です HttpClientインターフェース。このメソッドを使用して、HttpClientオブジェクトを作成します

CloseableHttpClient httpclient = HttpClients.createDefault();

ステップ2-応答ハンドラーをインスタンス化する

次のコード行を使用して、上記で作成した応答ハンドラオブジェクトをインスタンス化します-

ResponseHandler<String> responseHandler = new MyResponseHandler();

ステップ3-HttpGetオブジェクトを作成する

ザ・ HttpGet クラスは、URIを使用して指定されたサーバーの情報を取得するHTTPGETリクエストを表します。

HttpGetクラスをインスタンス化し、URIを表す文字列をパラメーターとしてコンストラクターに渡すことにより、HttpGetリクエストを作成します。

ResponseHandler<String> responseHandler = new MyResponseHandler();

ステップ4-応答ハンドラーを使用してGet要求を実行します

ザ・ CloseableHttpClient クラスには次のバリアントがあります execute() 2つのオブジェクトを受け入れるメソッド ResponseHandler およびHttpUriRequestであり、応答オブジェクトを返します。

String httpResponse = httpclient.execute(httpget, responseHandler);

次の例は、応答ハンドラーの使用法を示しています。

import java.io.IOException;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ResponseHandler;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;

class MyResponseHandler implements ResponseHandler<String>{
 
   public String handleResponse(final HttpResponse response) throws IOException{

      //Get the status of the response
      int status = response.getStatusLine().getStatusCode();
      if (status >= 200 && status < 300) {
         HttpEntity entity = response.getEntity();
         if(entity == null) {
            return "";
         } else {
            return EntityUtils.toString(entity);
         }

      } else {
         return ""+status;
      }
   }
}

public class ResponseHandlerExample {
   
   public static void main(String args[]) throws Exception{
 
      //Create an HttpClient object
      CloseableHttpClient httpclient = HttpClients.createDefault();

      //instantiate the response handler
      ResponseHandler<String> responseHandler = new MyResponseHandler();

      //Create an HttpGet object
      HttpGet httpget = new HttpGet("http://www.tutorialspoint.com/");

      //Execute the Get request by passing the response handler object and HttpGet object
      String httpresponse = httpclient.execute(httpget, responseHandler);

      System.out.println(httpresponse);
   }
}

出力

上記のプログラムは次の出力を生成します-

<!DOCTYPE html>
<!--[if IE 8]><html class = "ie ie8"> <![endif]-->
<!--[if IE 9]><html class = "ie ie9"> <![endif]-->
<!--[if gt IE 9]><!-->
<html lang = "en-US"> <!--<![endif]-->
<head>
<!-- Basic -->
<meta charset = "utf-8">
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" content = "width = device-width,initial-scale = 1.0,userscalable = yes">
<link href = "https://cdn.muicss.com/mui-0.9.39/extra/mui-rem.min.css"
rel = "stylesheet" type = "text/css" />
<link rel = "stylesheet" href = "/questions/css/home.css?v = 3" />
<script src = "/questions/js/jquery.min.js"></script>
<script src = "/questions/js/fontawesome.js"></script>
<script src = "https://cdn.muicss.com/mui-0.9.39/js/mui.min.js"></script>
</head>
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
<script>
window.dataLayer = window.dataLayer || [];
function gtag() {dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'UA-232293-17');
</script>
</body>

応答ハンドラーを使用する代わりにHTTP応答を手動で処理している場合は、すべてのhttp接続を自分で閉じる必要があります。この章では、接続を手動で閉じる方法について説明します。

HTTP接続を手動で閉じるときは、以下の手順に従ってください。

ステップ1-HttpClientオブジェクトを作成する

ザ・ createDefault() の方法 HttpClients クラスはクラスのオブジェクトを返します CloseableHttpClient、これはHttpClientインターフェイスの基本実装です。

この方法を使用して、 HttpClient 以下に示すオブジェクト-

CloseableHttpClient httpClient = HttpClients.createDefault();

ステップ2-try-finallyブロックを開始します

try-finallyブロックを開始し、tryブロックのプログラムに残りのコードを記述し、finallyブロックのCloseableHttpClientオブジェクトを閉じます。

CloseableHttpClient httpClient = HttpClients.createDefault();
try{
   //Remaining code . . . . . . . . . . . . . . .
}finally{
   httpClient.close();
}

ステップ3-HttpGetobjectを作成する

ザ・ HttpGet クラスは、URIを使用して指定されたサーバーの情報を取得するHTTPGETリクエストを表します。

URIを表す文字列を渡してHttpGetクラスをインスタンス化することにより、HTTPGETリクエストを作成します。

HttpGet httpGet = new HttpGet("http://www.tutorialspoint.com/");

ステップ4-Getリクエストを実行します

ザ・ execute() の方法 CloseableHttpClient オブジェクトは HttpUriRequest (インターフェイス)オブジェクト(つまり、HttpGet、HttpPost、HttpPut、HttpHeadなど)および応答オブジェクトを返します。

指定されたメソッドを使用してリクエストを実行します-

HttpResponse httpResponse = httpclient.execute(httpGet);

ステップ5-別の(ネストされた)試行を開始します-最後に

別のtry-finallyブロック(前のtry-finally内にネストされている)を開始し、このtryブロックのプログラムに残りのコードを記述して、finallyブロックのHttpResponseオブジェクトを閉じます。

CloseableHttpClient httpclient = HttpClients.createDefault();
try{
   . . . . . . .
   . . . . . . .
   CloseableHttpResponse httpresponse = httpclient.execute(httpget);
   try{
      . . . . . . .
      . . . . . . .
   }finally{
      httpresponse.close();
   }
}finally{
   httpclient.close();
}

次のプログラムに示すように、要求、応答ストリームなどのオブジェクトを作成/取得するたびに、次の行でtry finalブロックを開始し、try内に残りのコードを記述して、finallyブロック内のそれぞれのオブジェクトを閉じます。

import java.util.Scanner;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;

public class CloseConnectionExample {
   
   public static void main(String args[])throws Exception{
 
      //Create an HttpClient object
      CloseableHttpClient httpclient = HttpClients.createDefault();

      try{
         //Create an HttpGet object
         HttpGet httpget = new HttpGet("http://www.tutorialspoint.com/");

         //Execute the Get request
         CloseableHttpResponse httpresponse = httpclient.execute(httpget);

         try{
            Scanner sc = new Scanner(httpresponse.getEntity().getContent());
            while(sc.hasNext()) {
               System.out.println(sc.nextLine());
            }
         }finally{
            httpresponse.close();
         }
      }finally{
         httpclient.close();
      }
   }
}

出力

上記のプログラムを実行すると、次の出力が生成されます-

<!DOCTYPE html>
<!--[if IE 8]><html class = "ie ie8"> <![endif]-->
<!--[if IE 9]><html class = "ie ie9"> <![endif]-->
<!--[if gt IE 9]><!-->
<html lang = "en-US"> <!--<![endif]-->
<head>
<!-- Basic -->
<meta charset = "utf-8">
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" content = "width = device-width,initial-scale = 1.0,userscalable = yes">
<link href = "https://cdn.muicss.com/mui-0.9.39/extra/mui-rem.min.css"
rel = "stylesheet" type = "text/css" />
<link rel = "stylesheet" href = "/questions/css/home.css?v = 3" />
<script src = "/questions/js/jquery.min.js"></script>
<script src = "/questions/js/fontawesome.js"></script>
<script src = "https://cdn.muicss.com/mui-0.9.39/js/mui.min.js"></script>
</head>
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . 
<script>
window.dataLayer = window.dataLayer || [];
function gtag() {dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'UA-232293-17');
</script>
</body>
</html>

を使用して現在のHTTPリクエストを中止できます abort() メソッド、つまり、このメソッドを呼び出した後、特定の要求で、その実行は中止されます。

このメソッドが1回の実行後に呼び出された場合、その実行の応答は影響を受けず、後続の実行は中止されます。

次の例を見ると、HttpGetリクエストが作成され、を使用して使用されるリクエスト形式が出力されています。 getMethod()

次に、同じリクエストで別の実行を実行しました。再度1回目の実行でステータス行を印刷しました。最後に、2回目の実行のステータス行を出力しました。

説明したように、最初の実行(中止メソッドの前の実行)の応答が出力され(中止メソッドの後に書き込まれる2番目のステータス行を含む)、中止メソッドの後の現在の要求の後続のすべての実行が失敗し、例外。

import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;

public class HttpGetExample {
   public static void main(String args[]) throws Exception{
   
      //Creating an HttpClient object
      CloseableHttpClient httpclient = HttpClients.createDefault();

      //Creating an HttpGet object
      HttpGet httpget = new HttpGet("http://www.tutorialspoint.com/");

      //Printing the method used
      System.out.println(httpget.getMethod());
 
      //Executing the Get request
      HttpResponse httpresponse = httpclient.execute(httpget);

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

      httpget.abort();
      System.out.println(httpresponse.getEntity().getContentLength());
 
      //Executing the Get request
      HttpResponse httpresponse2 = httpclient.execute(httpget);
      System.out.println(httpresponse2.getStatusLine());
   }
}

出力

上記のプログラムを実行すると、次の出力が生成されます。

On executing, the above program generates the following output.
GET
HTTP/1.1 200 OK
-1
Exception in thread "main" org.apache.http.impl.execchain.RequestAbortedException:
Request aborted
at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:180)
at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:185)
at org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:89)
at org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:110)
at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:185)
at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:83)
at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:108)
at HttpGetExample.main(HttpGetExample.java:32)

インターセプターは、要求または応答を妨害または変更するのに役立つインターセプターです。プロトコルインターセプターは一般に、特定のヘッダーまたは関連するヘッダーのグループに作用します。HttpClientライブラリはインターセプターのサポートを提供します。

インターセプターをリクエストする

ザ・ HttpRequestInterceptorインターフェイスはリクエストインターセプターを表します。このインターフェースには、リクエストをインターセプトするためにコードのチャンクを記述する必要があるプロセスと呼ばれるメソッドが含まれています。

クライアント側では、このメソッドはリクエストをサーバーに送信する前に検証/処理し、サーバー側では、このメソッドはリクエストの本文を評価する前に実行されます。

リクエストインターセプターの作成

以下の手順に従って、リクエストインターセプターを作成できます。

Step 1 - Create an object of HttpRequestInterceptor

抽象メソッドプロセスを実装して、HttpRequestInterceptorインターフェイスのオブジェクトを作成します。

HttpRequestInterceptor requestInterceptor = new HttpRequestInterceptor() {
@Override
 public void process(HttpRequest request, HttpContext context) throws
HttpException, IOException {
   //Method implementation . . . . .
};

Step 2 - Instantiate CloseableHttpClient object

カスタムを作成する CloseableHttpClient 以下に示すように、上で作成したインターセプターをオブジェクトに追加します。

//Creating a CloseableHttpClient object
CloseableHttpClient httpclient =
HttpClients.custom().addInterceptorFirst(requestInterceptor).build();

このオブジェクトを使用すると、通常どおりリクエストの実行を実行できます。

次の例は、リクエストインターセプターの使用法を示しています。この例では、HTTP GETリクエストオブジェクトを作成し、それにsample-header、demoheader、test-headerの3つのヘッダーを追加しました。

の中に processor()インターセプターのメソッドでは、送信されたリクエストのヘッダーを確認しています。それらのヘッダーのいずれかがsample-header、それを削除して、その特定のリクエストのヘッダーのリストを表示しようとしています。

import java.io.IOException;
import org.apache.http.Header;
import org.apache.http.HttpException;
import org.apache.http.HttpRequest;
import org.apache.http.HttpRequestInterceptor;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.message.BasicHeader;
import org.apache.http.protocol.HttpContext;

public class InterceptorsExample {
 
   public static void main(String args[]) throws Exception{
      
      //Creating an HttpRequestInterceptor
      HttpRequestInterceptor requestInterceptor = new HttpRequestInterceptor() {
         @Override
         public void process(HttpRequest request, HttpContext context) throws
         HttpException, IOException {
            if(request.containsHeader("sample-header")) {
               System.out.println("Contains header sample-header, removing it..");
               request.removeHeaders("sample-header"); 
            }
            //Printing remaining list of headers
            Header[] headers= request.getAllHeaders();
            for (int i = 0; i<headers.length;i++) {
               System.out.println(headers[i].getName());
            }
         }
      };

      //Creating a CloseableHttpClient object
      CloseableHttpClient httpclient =
      HttpClients.custom().addInterceptorFirst(requestInterceptor).build();

      //Creating a request object
      HttpGet httpget1 = new HttpGet("https://www.tutorialspoint.com/");

      //Setting the header to it
      httpget1.setHeader(new BasicHeader("sample-header","My first header"));
      httpget1.setHeader(new BasicHeader("demo-header","My second header"));
      httpget1.setHeader(new BasicHeader("test-header","My third header"));

      //Executing the request
      HttpResponse httpresponse = httpclient.execute(httpget1);

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

出力

上記のプログラムを実行すると、次の出力が生成されます-

Contains header sample-header, removing it..
demo-header
test-header
HTTP/1.1 200 OK

応答インターセプター

ザ・ HttpResponseInterceptorインターフェイスは、応答インターセプターを表します。このインターフェースには、process()。このメソッドでは、応答をインターセプトするコードのチャンクを記述する必要があります。

サーバー側では、このメソッドは応答をクライアントに送信する前に検証/処理し、クライアント側では、このメソッドは応答の本文を評価する前に実行されます。

応答インターセプターの作成

以下の手順に従って、応答インターセプターを作成できます。

Step 1 - Create an object of HttpResponseInterceptor

のオブジェクトを作成します HttpResponseInterceptor その抽象メソッドを実装することによるインターフェース process

HttpResponseInterceptor responseInterceptor = new HttpResponseInterceptor() {
   @Override
   public void process(HttpResponse response, HttpContext context) throws HttpException, IOException {
      //Method implementation . . . . . . . .
   }
};

ステップ2:CloseableHttpClientオブジェクトをインスタンス化する

カスタムを作成する CloseableHttpClient 以下に示すように、上で作成したインターセプターをオブジェクトに追加します。

//Creating a CloseableHttpClient object
CloseableHttpClient httpclient =
HttpClients.custom().addInterceptorFirst(responseInterceptor).build();

このオブジェクトを使用すると、通常どおりリクエストの実行を実行できます。

次の例は、応答インターセプターの使用法を示しています。この例では、プロセッサーの応答に、sample-header、demo-header、およびtest-headerの3つのヘッダーを追加しました。

リクエストを実行してレスポンスを取得した後、を使用してレスポンスのすべてのヘッダーの名前を出力しました。 getAllHeaders() 方法。

また、出力では、リスト内の3つのヘッダーの名前を確認できます。

import java.io.IOException;
import org.apache.http.Header;
import org.apache.http.HttpException;
import org.apache.http.HttpResponse;
import org.apache.http.HttpResponseInterceptor;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.protocol.HttpContext;

public class ResponseInterceptorsExample {

   public static void main(String args[]) throws Exception{
      
      //Creating an HttpRequestInterceptor
      HttpResponseInterceptor responseInterceptor = new HttpResponseInterceptor() {
         @Override
         public void process(HttpResponse response, HttpContext context) throws
         HttpException, IOException {
            System.out.println("Adding header sample_header, demo-header, test_header to the response");
            response.setHeader("sample-header", "My first header");
            response.setHeader("demo-header", "My second header");
            response.setHeader("test-header", "My third header"); 
         }
      };

      //Creating a CloseableHttpClient object
      CloseableHttpClient httpclient = HttpClients.custom().addInterceptorFirst(responseInterceptor).build();

      //Creating a request object
      HttpGet httpget1 = new HttpGet("https://www.tutorialspoint.com/");

      //Executing the request
      HttpResponse httpresponse = httpclient.execute(httpget1); 

      //Printing remaining list of headers
      Header[] headers = httpresponse.getAllHeaders();
 
      for (int i = 0; i<headers.length;i++) {
         System.out.println(headers[i].getName());
      }
   }
}

出力

上記のプログラムを実行すると、次の結果が生成されます。

On executing the above program generates the following output.
Adding header sample_header, demo-header, test_header to the response
Accept-Ranges
Access-Control-Allow-Headers
Access-Control-Allow-Origin
Cache-Control
Content-Type
Date
Expires
Last-Modified
Server
Vary
X-Cache
sample-header
demo-header
test-header

HttpClientを使用すると、ユーザー名とパスワードが必要なWebサイトに接続できます。この章では、ユーザー名とパスワードを要求するサイトに対してクライアント要求を実行する方法について説明します。

ステップ1-CredentialsProviderオブジェクトを作成する

ザ・ CredentialsProviderインターフェイスは、ユーザーのログイン資格情報を保持するためのコレクションを維持します。オブジェクトをインスタンス化することで作成できますBasicCredentialsProvider クラス、このインターフェイスのデフォルトの実装。

CredentialsProvider credentialsPovider = new BasicCredentialsProvider();

ステップ2-資格情報を設定する

を使用して、必要な資格情報をCredentialsProviderオブジェクトに設定できます。 setCredentials() 方法。

このメソッドは、以下に示すように2つのオブジェクトを受け入れます-

  • AuthScope object −ホスト名、ポート番号、認証スキーム名などの詳細を指定する認証スコープ。

  • Credentials object −資格情報(ユーザー名、パスワード)を指定します。

を使用して資格情報を設定します setCredentials() 以下に示すように、ホストとプロキシの両方のメソッド-

credsProvider.setCredentials(new AuthScope("example.com", 80), 
   new UsernamePasswordCredentials("user", "mypass"));
credsProvider.setCredentials(new AuthScope("localhost", 8000), 
   new UsernamePasswordCredentials("abc", "passwd"));

ステップ3-HttpClientBuilderオブジェクトを作成する

作成する HttpClientBuilder を使用して custom() の方法 HttpClients クラス。

//Creating the HttpClientBuilder
HttpClientBuilder clientbuilder = HttpClients.custom();

ステップ4-credentialsPoviderを設定します

上記で作成したcredentialsPoviderオブジェクトは、を使用してHttpClientBuilderに設定できます。 setDefaultCredentialsProvider() 方法。

前の手順で作成したCredentialProviderオブジェクトをクライアントビルダーに渡して、 CredentialsProvider object() 以下に示す方法。

clientbuilder = clientbuilder.setDefaultCredentialsProvider(credsProvider);

ステップ5-CloseableHttpClientを構築する

ビルド CloseableHttpClient を使用するオブジェクト build() の方法 HttpClientBuilder クラス。

CloseableHttpClient httpclient = clientbuilder.build()

ステップ6-HttpGetオブジェクトを作成して実行します

HttpGetクラスをインスタンス化して、HttpRequestオブジェクトを作成します。を使用してこのリクエストを実行しますexecute() 方法。

//Creating a HttpGet object
HttpGet httpget = new HttpGet("https://www.tutorialspoint.com/ ");

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

以下は、ユーザー認証を必要とするターゲットサイトに対するHTTPリクエストの実行を示すサンプルプログラムです。

import org.apache.http.Header;
import org.apache.http.HttpResponse;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.Credentials;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.BasicCredentialsProvider;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;

public class UserAuthenticationExample {
   
   public static void main(String args[]) throws Exception{
      
      //Create an object of credentialsProvider
      CredentialsProvider credentialsPovider = new BasicCredentialsProvider();

      //Set the credentials
      AuthScope scope = new AuthScope("https://www.tutorialspoint.com/questions/", 80);
      
      Credentials credentials = new UsernamePasswordCredentials("USERNAME", "PASSWORD");
      credentialsPovider.setCredentials(scope,credentials);

      //Creating the HttpClientBuilder
      HttpClientBuilder clientbuilder = HttpClients.custom();

      //Setting the credentials
      clientbuilder = clientbuilder.setDefaultCredentialsProvider(credentialsPovider);

      //Building the CloseableHttpClient object
      CloseableHttpClient httpclient = clientbuilder.build();

      //Creating a HttpGet object
      HttpGet httpget = new HttpGet("https://www.tutorialspoint.com/questions/index.php");

      //Printing the method used
      System.out.println(httpget.getMethod()); 

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

      //Printing the status line
      System.out.println(httpresponse.getStatusLine());
      int statusCode = httpresponse.getStatusLine().getStatusCode();
      System.out.println(statusCode);

      Header[] headers= httpresponse.getAllHeaders();
      for (int i = 0; i<headers.length;i++) {
         System.out.println(headers[i].getName());
      }
   }
}

出力

上記のプログラムを実行すると、次の出力が生成されます。

GET
HTTP/1.1 200 OK
200

プロキシサーバーは、クライアントとインターネットの間の中間サーバーです。プロキシサーバーは、次の基本機能を提供します-

  • ファイアウォールとネットワークデータのフィルタリング

  • ネットワーク接続の共有

  • データキャッシング

HttpClientライブラリを使用すると、プロキシを使用してHTTPリクエストを送信できます。以下の手順に従ってください-

ステップ1-HttpHostオブジェクトを作成する

インスタンス化する HttpHost のクラス org.apache.http プロキシホストの名前を表す文字列パラメータ(リクエストの送信元)をコンストラクタに渡すことでパッケージ化します。

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

同様に、リクエストの送信先となるターゲットホストを表す別のHttpHostオブジェクトを作成します。

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

ステップ2-HttpRoutePlannerオブジェクトを作成する

ザ・ HttpRoutePlannerインターフェイスは、指定されたホストへのルートを計算します。をインスタンス化して、このインターフェイスのオブジェクトを作成しますDefaultProxyRoutePlannerクラス、このインターフェースの実装。コンストラクターへのパラメーターとして、上記で作成したプロキシホストを渡します-

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

ステップ3-ルートプランナーをクライアントビルダーに設定する

を使用して custom() の方法 HttpClients クラス、作成 HttpClientBuilder オブジェクトと、このオブジェクトに、上記で作成したルートプランナーを使用して設定します。 setRoutePlanner() 方法。

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

clientBuilder = clientBuilder.setRoutePlanner(routePlanner);

手順4-CloseableHttpClientオブジェクトを作成する

ビルド CloseableHttpClient を呼び出すことによってオブジェクト build() 方法。

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

ステップ5-HttpGetobjectを作成する

インスタンス化してHTTPGETリクエストを作成します HttpGet クラス。

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

ステップ6-リクエストを実行する

の亜種の1つ execute() メソッドは HttpHost そして HttpRequestオブジェクトを作成し、リクエストを実行します。このメソッドを使用してリクエストを実行します-

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

次の例は、プロキシ経由でサーバーにHTTPリクエストを送信する方法を示しています。この例では、ローカルホスト経由でgoogle.comにHTTPGETリクエストを送信しています。応答のヘッダーと応答の本文を印刷しました。

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));
      }
   }
}

出力

上記のプログラムを実行すると、次の出力が生成されます。

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>

この章では、例を使用して、ユーザー名とパスワードを使用して認証されたHttpRequestを作成し、プロキシを介してターゲットホストにトンネリングする方法を学習します。

ステップ1-CredentialsProviderオブジェクトを作成する

CredentialsProviderインターフェイスは、ユーザーのログイン資格情報を保持するためのコレクションを維持します。このインターフェイスのデフォルトの実装であるBasicCredentialsProviderクラスをインスタンス化することにより、そのオブジェクトを作成できます。

CredentialsProvider credentialsPovider = new BasicCredentialsProvider();

ステップ2-資格情報を設定する

を使用して、必要な資格情報をCredentialsProviderオブジェクトに設定できます。 setCredentials()方法。このメソッドは2つのオブジェクトを受け入れます-

  • AuthScope object −ホスト名、ポート番号、認証スキーム名などの詳細を指定する認証スコープ。

  • Credentials object−資格情報(ユーザー名、パスワード)を指定します。を使用して資格情報を設定しますsetCredentials() 以下に示すように、ホストとプロキシの両方のメソッド。

credsProvider.setCredentials(new AuthScope("example.com", 80), new
   UsernamePasswordCredentials("user", "mypass"));
credsProvider.setCredentials(new AuthScope("localhost", 8000), new
   UsernamePasswordCredentials("abc", "passwd"));

ステップ3-HttpClientBuilderオブジェクトを作成する

作成する HttpClientBuilder を使用して custom() の方法 HttpClients 以下に示すクラス-

//Creating the HttpClientBuilder
HttpClientBuilder clientbuilder = HttpClients.custom();

ステップ4-CredentialsProviderを設定する

を使用して、CredentialsProviderオブジェクトをHttpClientBuilderオブジェクトに設定できます。 setDefaultCredentialsProvider()方法。以前に作成したものを渡すCredentialsProvider このメソッドに反対します。

clientbuilder = clientbuilder.setDefaultCredentialsProvider(credsProvider);

ステップ5-CloseableHttpClientを構築する

ビルド CloseableHttpClient を使用するオブジェクト build() 方法。

CloseableHttpClient httpclient = clientbuilder.build();

ステップ6-プロキシとターゲットホストを作成する

をインスタンス化して、ターゲットホストとプロキシホストを作成します HttpHost クラス。

//Creating the target and proxy hosts
HttpHost target = new HttpHost("example.com", 80, "http");
HttpHost proxy = new HttpHost("localhost", 8000, "http");

ステップ7-プロキシを設定し、RequestConfigオブジェクトを作成します

作成する RequestConfig.Builder を使用するオブジェクト custom()方法。以前に作成したproxyHostオブジェクトをに設定しますRequestConfig.Builder を使用して setProxy()方法。最後に、RequestConfig を使用するオブジェクト build() 方法。

RequestConfig.Builder reqconfigconbuilder= RequestConfig.custom();
reqconfigconbuilder = reqconfigconbuilder.setProxy(proxyHost);
RequestConfig config = reqconfigconbuilder.build();

ステップ8-HttpGetリクエストオブジェクトを作成し、それにconfigオブジェクトを設定します。

作成する HttpGetHttpGetクラスをインスタンス化してオブジェクトを作成します。前の手順で作成した構成オブジェクトを、を使用してこのオブジェクトに設定します。setConfig() 方法。

//Create the HttpGet request object
HttpGet httpGet = new HttpGet("/");

//Setting the config to the request
httpget.setConfig(config);

ステップ9-リクエストを実行します

HttpHostオブジェクト(ターゲット)とリクエスト(HttpGet)をパラメータとしてに渡すことでリクエストを実行します execute() 方法。

HttpResponse httpResponse = httpclient.execute(targetHost, httpget);

次の例は、ユーザー名とパスワードを使用してプロキシ経由でHTTPリクエストを実行する方法を示しています。

import org.apache.http.HttpHost;
import org.apache.http.HttpResponse;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.BasicCredentialsProvider;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;

public class ProxyAuthenticationExample {
   public static void main(String[] args) throws Exception {

      //Creating the CredentialsProvider object
      CredentialsProvider credsProvider = new BasicCredentialsProvider();

      //Setting the credentials
      credsProvider.setCredentials(new AuthScope("example.com", 80), 
         new UsernamePasswordCredentials("user", "mypass"));
      credsProvider.setCredentials(new AuthScope("localhost", 8000), 
         new UsernamePasswordCredentials("abc", "passwd"));

      //Creating the HttpClientBuilder
      HttpClientBuilder clientbuilder = HttpClients.custom();

      //Setting the credentials
      clientbuilder = clientbuilder.setDefaultCredentialsProvider(credsProvider);
      
      //Building the CloseableHttpClient object
      CloseableHttpClient httpclient = clientbuilder.build();


      //Create the target and proxy hosts
      HttpHost targetHost = new HttpHost("example.com", 80, "http");
      HttpHost proxyHost = new HttpHost("localhost", 8000, "http");

      //Setting the proxy
      RequestConfig.Builder reqconfigconbuilder= RequestConfig.custom();
      reqconfigconbuilder = reqconfigconbuilder.setProxy(proxyHost);
      RequestConfig config = reqconfigconbuilder.build();

      //Create the HttpGet request object
      HttpGet httpget = new HttpGet("/");

      //Setting the config to the request
      httpget.setConfig(config);
 
      //Printing the status line
      HttpResponse response = httpclient.execute(targetHost, httpget);
      System.out.println(response.getStatusLine());

   }
}

出力

上記のプログラムを実行すると、次の出力が生成されます。

HTTP/1.1 200 OK

HttpClientライブラリを使用すると、リクエストを送信したり、パラメータを渡してフォームにログインしたりできます。

以下の手順に従って、フォームにログインしてください。

ステップ1-HttpClientオブジェクトを作成する

ザ・ createDefault() の方法 HttpClients クラスはクラスのオブジェクトを返します CloseableHttpClient、これはHttpClientインターフェイスの基本実装です。このメソッドを使用して、HttpClientオブジェクトを作成します-

CloseableHttpClient httpClient = HttpClients.createDefault();

ステップ2-RequestBuilderオブジェクトを作成する

クラス RequestBuilderパラメータを追加してリクエストを作成するために使用されます。リクエストタイプがPUTまたはPOSTの場合、URLエンコードされたエンティティとしてパラメータをリクエストに追加します

post()メソッドを使用して(タイプPOSTの)RequestBuilderオブジェクトを作成します。

//Building the post request object
RequestBuilder reqbuilder = RequestBuilder.post();

ステップ3-URIとパラメーターをRequestBuilderに設定します。

を使用して、URIとパラメーターをRequestBuilderオブジェクトに設定します。 setUri() そして addParameter() RequestBuilderクラスのメソッド。

//Set URI and parameters
RequestBuilder reqbuilder = reqbuilder.setUri("http://httpbin.org/post");
reqbuilder = reqbuilder1.addParameter("Name", "username").addParameter("password", "password");

手順4-HttpUriRequestオブジェクトを作成する

必要なパラメータを設定した後、 HttpUriRequest を使用するオブジェクト build() 方法。

//Building the HttpUriRequest object
HttpUriRequest httppost = reqbuilder2.build();

ステップ5-リクエストを実行する

CloseableHttpClientオブジェクトのexecuteメソッドは、HttpUriRequest(インターフェイス)オブジェクト(つまり、HttpGet、HttpPost、HttpPut、HttpHeadなど)を受け入れ、応答オブジェクトを返します。

前の手順で作成したHttpUriRequestを、に渡して実行します。 execute() 方法。

//Execute the request
HttpResponse httpresponse = httpclient.execute(httppost);

次の例は、ログイン資格情報を送信してフォームにログオンする方法を示しています。ここでは、2つのパラメータを送信しました-username and password フォームに送信し、メッセージエンティティとリクエストのステータスを出力しようとしました。

import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpUriRequest;
import org.apache.http.client.methods.RequestBuilder;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import java.io.IOException;
import java.net.URISyntaxException;

public class FormLoginExample {
 
   public static void main(String args[]) throws Exception {

      //Creating CloseableHttpClient object
      CloseableHttpClient httpclient = HttpClients.createDefault();
 
      //Creating the RequestBuilder object
      RequestBuilder reqbuilder = RequestBuilder.post();

      //Setting URI and parameters
      RequestBuilder reqbuilder1 = reqbuilder.setUri("http://httpbin.org/post");
      RequestBuilder reqbuilder2 = reqbuilder1.addParameter("Name", 
         "username").addParameter("password", "password");

      //Building the HttpUriRequest object
      HttpUriRequest httppost = reqbuilder2.build();

      //Executing the request
      HttpResponse httpresponse = httpclient.execute(httppost);

      //Printing the status and the contents of the response
      System.out.println(EntityUtils.toString(httpresponse.getEntity()));
      System.out.println(httpresponse.getStatusLine());
   }
}

出力

上記のプログラムを実行すると、次の出力が生成されます。

{
   "args": {},
   "data": "",
   "files": {},
   "form": {
      "Name": "username",
      "password": "password"
   },
   "headers": {
      "Accept-Encoding": "gzip,deflate",
      "Connection": "close",
      "Content-Length": "31",
      "Content-Type": "application/x-www-form-urlencoded; charset = UTF-8",
      "Host": "httpbin.org",
      "User-Agent": "Apache-HttpClient/4.5.6 (Java/1.8.0_91)"
   },
   "json": null,
   "origin": "117.216.245.180",
   "url": "http://httpbin.org/post"
}
HTTP/1.1 200 OK

Cookieを使用したフォームログイン

フォームにデフォルトを作成する代わりにCookieが保存されている場合 CloseableHttpClient オブジェクト。

Create a CookieStore object BasicCookieStoreクラスをインスタンス化する。

//Creating a BasicCookieStore object
BasicCookieStore cookieStore = new BasicCookieStore();

Create a HttpClientBuilder を使用して custom() の方法 HttpClients クラス。

//Creating an HttpClientBuilder object
HttpClientBuilder clientbuilder = HttpClients.custom();

Set the cookie store to the client builder setDefaultCookieStore()メソッドを使用します。

//Setting default cookie store to the client builder object
Clientbuilder = clientbuilder.setDefaultCookieStore(cookieStore);

ビルド CloseableHttpClient を使用するオブジェクト build() 方法。

//Building the CloseableHttpClient object
CloseableHttpClient httpclient = clientbuilder1.build();

ビルド HttpUriRequest リクエストを実行することにより、上記で指定されたオブジェクト。

ページにCookieが保存されている場合、渡したパラメータがCookieストアに追加されます。

あなたはの内容を印刷することができます CookieStore パラメータを表示できるオブジェクト(ケースに保存されている前のパラメータと一緒に)。

Cookieを印刷するには、からすべてのCookieを取得します CookieStore を使用するオブジェクト getCookies()方法。このメソッドはListオブジェクト。Iteratorを使用して、リストオブジェクトの内容を次のように出力します-

//Printing the cookies
List list = cookieStore.getCookies();

System.out.println("list of cookies");
Iterator it = list.iterator();
if(it.hasNext()) {
   System.out.println(it.next());
}

クッキーはクライアントコンピュータに保存されるテキストファイルであり、さまざまな情報追跡の目的で保持されます。

HttpClientは、Cookieを作成および管理できるCookieのサポートを提供します。

クッキーの作成

以下の手順に従って、HttpClientライブラリを使用してCookieを作成します。

ステップ1-Cookiestoreオブジェクトを作成する

ザ・ CookieStoreインターフェイスは、Cookieオブジェクトの抽象ストアを表します。インスタンス化することでCookieストアを作成できますBasicCookieStore クラス、このインターフェイスのデフォルトの実装。

//Creating the CookieStore object
CookieStore cookieStore = new BasicCookieStore();

ステップ2-ClientCookieオブジェクトを作成する

Cookieの機能に加えて、ClientCookieはサーバー内の元のCookieを取得できます。インスタンス化することでクライアントCookieを作成できますBasicClientCookieクラス。このクラスのコンストラクターには、特定のCookieに保存するキーと値のペアを渡す必要があります。

//Creating client cookie
BasicClientCookie clientCookie = new BasicClientCookie("name","Raju");

ステップ3-Cookieに値を設定する

クライアントCookieに対して、それぞれの方法を使用して、パス、値、バージョン、有効期限、ドメイン、コメント、および属性を設定/削除できます。

Calendar myCal = new GregorianCalendar(2018, 9, 26);
Date expiryDate = myCal.getTime();
clientcookie.setExpiryDate(expiryDate);
clientcookie.setPath("/");
clientcookie.setSecure(true);
clientcookie.setValue("25");
clientcookie.setVersion(5);

ステップ4-クッキーストアにクッキーを追加する

を使用してCookieストアにCookieを追加できます addCookie() の方法 BasicCookieStore クラス。

必要なCookieをに追加します Cookiestore

//Adding the created cookies to cookie store
cookiestore.addCookie(clientcookie);

次の例は、Cookieを作成してCookieストアに追加する方法を示しています。ここでは、ドメインとパスの値を設定してCookieストア、つまり一連のCookieを作成し、それらをCookieストアに追加しました。

import org.apache.http.client.CookieStore;
import org.apache.http.impl.client.BasicCookieStore;
import org.apache.http.impl.cookie.BasicClientCookie;

public class CookieHandlingExample {
   
   public static void main(String args[]) throws Exception{
      
      //Creating the CookieStore object
      CookieStore cookiestore = new BasicCookieStore();
 
      //Creating client cookies
      BasicClientCookie clientcookie1 = new BasicClientCookie("name","Raju");
      BasicClientCookie clientcookie2 = new BasicClientCookie("age","28");
      BasicClientCookie clientcookie3 = new BasicClientCookie("place","Hyderabad");

      //Setting domains and paths to the created cookies
      clientcookie1.setDomain(".sample.com");
      clientcookie2.setDomain(".sample.com");
      clientcookie3.setDomain(".sample.com");

      clientcookie1.setPath("/");
      clientcookie2.setPath("/");
      clientcookie3.setPath("/");
 
      //Adding the created cookies to cookie store
      cookiestore.addCookie(clientcookie1);
      cookiestore.addCookie(clientcookie2);
      cookiestore.addCookie(clientcookie3);
   }
}

クッキーの取得

を使用してCookieストアに追加されたCookieを取得できます getCookies() の方法 asicCookieStoreクラス。このメソッドは、Cookieストア内のすべてのCookieを保持するリストを返します。

以下に示すように、イテレータを使用してCookieストアの内容を印刷できます。

//Retrieving the cookies
List list = cookieStore.getCookies();

//Creating an iterator to the obtained list
Iterator it = list.iterator();
while(it.hasNext()) {
   System.out.println(it.next());
}

次の例は、CookieストアからCookieを取得する方法を示しています。ここでは、一連のCookieをCookieストアに追加し、それらを取得します。

import org.apache.http.client.CookieStore;
import org.apache.http.impl.client.BasicCookieStore;
import org.apache.http.impl.cookie.BasicClientCookie;

public class CookieHandlingExample {
 
   public static void main(String args[]) throws Exception{
      
      //Creating the CookieStore object
      CookieStore cookiestore = new BasicCookieStore();
      
      //Creating client cookies
      BasicClientCookie clientcookie1 = new BasicClientCookie("name","Raju");
      BasicClientCookie clientcookie2 = new BasicClientCookie("age","28");
      BasicClientCookie clientcookie3 = new BasicClientCookie("place","Hyderabad");

      //Setting domains and paths to the created cookies
      clientcookie1.setDomain(".sample.com");
      clientcookie2.setDomain(".sample.com");
      clientcookie3.setDomain(".sample.com");

      clientcookie1.setPath("/");
      clientcookie2.setPath("/");
      clientcookie3.setPath("/");
 
      //Adding the created cookies to cookie store
      cookiestore.addCookie(clientcookie1);
      cookiestore.addCookie(clientcookie2);
      cookiestore.addCookie(clientcookie3);
   }
}

出力

このプログラムを実行すると、次の出力が生成されます。

[version: 0][name: age][value: 28][domain: .sample.com][path: /][expiry: null]
[version: 0][name: name][value: Raju][domain: my.example.com][path: /][expiry:
null]
[version: 0][name: place][value: Hyderabad][domain: .sample.com][path:
/][expiry: null]

マルチスレッドプログラムには、同時に実行できる2つ以上のパーツが含まれており、各パーツは、使用可能なリソースを最適に利用して、異なるタスクを同時に処理できます。

マルチスレッドのHttpClientプログラムを作成することにより、複数のスレッドからの要求を実行できます。

スレッドから複数のクライアントリクエストを連続して実行する場合は、を作成する必要があります ClientConnectionPoolManager。それはのプールを維持しますHttpClientConnections スレッドからの複数のリクエストを処理します。

接続マネージャーは、ルートに基づいて接続をプールします。マネージャが特定のルートへの接続を持っている場合、新しい接続を作成する代わりに、プールから既存の接続をリースすることにより、それらのルートで新しい要求を処理します。

手順に従って、複数のスレッドからリクエストを実行します-

ステップ1-クライアント接続プールマネージャの作成

をインスタンス化して、クライアント接続プールマネージャを作成します PoolingHttpClientConnectionManager クラス。

PoolingHttpClientConnectionManager connManager = new
   PoolingHttpClientConnectionManager();

ステップ2-接続の最大数を設定します

を使用して、プール内の接続の最大数を設定します。 setMaxTotal() 方法。

//Set the maximum number of connections in the pool
connManager.setMaxTotal(100);

ステップ3-ClientBuilderオブジェクトを作成する

作成する ClientBuilder を使用して接続マネージャーを設定することによるオブジェクト setConnectionManager() 以下に示す方法-

HttpClientBuilder clientbuilder =
HttpClients.custom().setConnectionManager(connManager);

ステップ4-HttpGetリクエストオブジェクトを作成する

目的のURIをコンストラクターにパラメーターとして渡すことにより、HttpGetクラスをインスタンス化します。

HttpGet httpget1 = new HttpGet("URI1");
HttpGet httpget2 = new HttpGet("URI2");
. . . . . . . . . . . .

ステップ5-runメソッドを実装する

クラスを作成し、それをスレッドにして(スレッドクラスを拡張するか、Runnableインターフェイスを実装することにより)、runメソッドを実装したことを確認してください。

public class ClientMultiThreaded extends Thread {
   public void run() {
      //Run method implementation . . . . . . . . . .
   }
}

ステップ6-スレッドオブジェクトを作成する

上で作成したThreadクラス(ClientMultiThreaded)をインスタンス化して、スレッドオブジェクトを作成します。

HttpClientオブジェクト、それぞれのHttpGetオブジェクト、およびIDを表す整数をこれらのスレッドに渡します。

ClientMultiThreaded thread1 = new ClientMultiThreaded(httpclient,httpget1, 1);
ClientMultiThreaded thread2 = new ClientMultiThreaded(httpclient,httpget2, 2);
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

ステップ7-スレッドを開始して参加する

を使用してすべてのスレッドを開始します start() メソッドと結合を使用してそれらを結合します method()

thread1.start();
thread2.start();
. . . . . . . .
thread1.join();
thread2.join();
. . . . . . . . . . . .

ステップ8-メソッド実装を実行する

runメソッド内で、リクエストを実行し、レスポンスを取得して、結果を出力します。

次の例は、複数のスレッドから同時にHTTPリクエストを実行する方法を示しています。この例では、さまざまなスレッドからさまざまな要求を実行し、ステータスと各クライアントによって読み取られたバイト数を出力しようとしています。

import org.apache.http.HttpEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
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.PoolingHttpClientConnectionManager;
import org.apache.http.util.EntityUtils;

public class ClientMultiThreaded extends Thread {
   CloseableHttpClient httpClient;
   HttpGet httpget;
   int id;
 
   public ClientMultiThreaded(CloseableHttpClient httpClient, HttpGet httpget,
   int id) {
      this.httpClient = httpClient;
      this.httpget = httpget;
      this.id = id;
   }
   @Override
   public void run() {
      try{
         //Executing the request
         CloseableHttpResponse httpresponse = httpClient.execute(httpget);

         //Displaying the status of the request.
         System.out.println("status of thread "+id+":"+httpresponse.getStatusLine());

         //Retrieving the HttpEntity and displaying the no.of bytes read
         HttpEntity entity = httpresponse.getEntity();
         if (entity != null) {
            System.out.println("Bytes read by thread thread "+id+":
               "+EntityUtils.toByteArray(entity).length);
         }
      }catch(Exception e) {
         System.out.println(e.getMessage());
      }
   }
      
   public static void main(String[] args) throws Exception {

      //Creating the Client Connection Pool Manager by instantiating the PoolingHttpClientConnectionManager class.
      PoolingHttpClientConnectionManager connManager = new PoolingHttpClientConnectionManager();

      //Set the maximum number of connections in the pool
      connManager.setMaxTotal(100);

      //Create a ClientBuilder Object by setting the connection manager
      HttpClientBuilder clientbuilder = HttpClients.custom().setConnectionManager(connManager);
 
      //Build the CloseableHttpClient object using the build() method.
      CloseableHttpClient httpclient = clientbuilder.build();

      //Creating the HttpGet requests
      HttpGet httpget1 = new HttpGet("http://www.tutorialspoint.com/");
      HttpGet httpget2 = new HttpGet("http://www.google.com/");
      HttpGet httpget3 = new HttpGet("https://www.qries.com/");
      HttpGet httpget4 = new HttpGet("https://in.yahoo.com/");
 
      //Creating the Thread objects
      ClientMultiThreaded thread1 = new ClientMultiThreaded(httpclient,httpget1, 1);
      ClientMultiThreaded thread2 = new ClientMultiThreaded(httpclient,httpget2, 2);
      ClientMultiThreaded thread3 = new ClientMultiThreaded(httpclient,httpget3, 3);
      ClientMultiThreaded thread4 = new ClientMultiThreaded(httpclient,httpget4, 4);

      //Starting all the threads
      thread1.start();
      thread2.start();
      thread3.start();
      thread4.start();

      //Joining all the threads
      thread1.join();
      thread2.join();
      thread3.join();
      thread4.join();
   }
}

出力

上記のプログラムを実行すると、次の出力が生成されます。

status of thread 1: HTTP/1.1 200 OK
Bytes read by thread thread 1: 36907
status of thread 2: HTTP/1.1 200 OK
Bytes read by thread thread 2: 13725
status of thread 3: HTTP/1.1 200 OK
Bytes read by thread thread 3: 17319
status of thread 4: HTTP/1.1 200 OK
Bytes read by thread thread 4: 127018

Secure Socket Layerを使用すると、クライアントとサーバーの間に安全な接続を確立できます。クレジットカード番号、ユーザー名、パスワード、ピンなどの機密情報を保護するのに役立ちます。

を使用して独自のSSLコンテキストを作成することにより、接続をより安全にすることができます。 HttpClient 図書館。

以下の手順に従って、HttpClientライブラリを使用してSSLContextをカスタマイズします-

ステップ1-SSLContextBuilderオブジェクトを作成する

SSLContextBuilderSSLContextオブジェクトのビルダーです。を使用してオブジェクトを作成しますcustom() の方法 SSLContexts クラス。

//Creating SSLContextBuilder object
SSLContextBuilder SSLBuilder = SSLContexts.custom();

ステップ2-キーストアをロードします

パスで Java_home_directory/jre/lib/security/、cacertsという名前のファイルを見つけることができます。これをキーストアファイル(拡張子.jks)として保存します。キーストアファイルとそのパスワード(changeit デフォルトで)を使用して loadTrustMaterial() の方法 SSLContextBuilder クラス。

//Loading the Keystore file
File file = new File("mykeystore.jks");
SSLBuilder = SSLBuilder.loadTrustMaterial(file, "changeit".toCharArray());

ステップ3-SSLContextオブジェクトを作成する

SSLContextオブジェクトは、セキュアソケットプロトコルの実装を表します。を使用してSSLContextを構築しますbuild() 方法。

//Building the SSLContext
SSLContext sslContext = SSLBuilder.build();

ステップ4-SSLConnectionSocketFactoryオブジェクトを作成する

SSLConnectionSocketFactoryTSLおよびSSL接続用のレイヤードソケットファクトリです。これを使用すると、信頼できる証明書のリストを使用してHttpsサーバーを検証し、指定されたHttpsサーバーを認証できます。

これはさまざまな方法で作成できます。作成方法に応じてSSLConnectionSocketFactory オブジェクト、すべてのホストを許可する、自己署名証明書のみを許可する、特定のプロトコルのみを許可するなどができます。

To allow only particular protocols、作成する SSLConnectionSocketFactory SSLContextオブジェクトを渡すことによるオブジェクト、プロトコルを表す文字列配列をサポートする必要があり、暗号スイートを表す文字列配列をサポートする必要があり、HostnameVerifierオブジェクトをそのコンストラクターに渡します。

new SSLConnectionSocketFactory(sslcontext, new String[]{"TLSv1"}, null,    
   SSLConnectionSocketFactory.getDefaultHostnameVerifier());

To allow all hosts, 作成する SSLConnectionSocketFactory SSLContextオブジェクトとを渡すことによってオブジェクト NoopHostnameVerifier オブジェクト。

//Creating SSLConnectionSocketFactory SSLConnectionSocketFactory object
SSLConnectionSocketFactory sslConSocFactory = new SSLConnectionSocketFactory(sslcontext, new NoopHostnameVerifier());

ステップ5-HttpClientBuilderオブジェクトを作成する

を使用してHttpClientBuilderオブジェクトを作成します custom() の方法 HttpClients クラス。

//Creating HttpClientBuilder
HttpClientBuilder clientbuilder = HttpClients.custom();

手順6-SSLConnectionSocketFactoryオブジェクトを設定する

SSLConnectionSocketFactoryオブジェクトをに設定します HttpClientBuilder を使用して setSSLSocketFactory() 方法。

//Setting the SSLConnectionSocketFactory
clientbuilder = clientbuilder.setSSLSocketFactory(sslConSocFactory);

手順7-CloseableHttpClientオブジェクトを作成する

ビルド CloseableHttpClient を呼び出すことによってオブジェクト build() 方法。

//Building the CloseableHttpClient
CloseableHttpClient httpclient = clientbuilder.build();

ステップ8-HttpGetオブジェクトを作成する

ザ・ HttpGet クラスは、URIを使用して指定されたサーバーの情報を取得するHTTPGETリクエストを表します。

URIを表す文字列を渡してHttpGetクラスをインスタンス化することにより、HTTPGETリクエストを作成します。

//Creating the HttpGet request
HttpGet httpget = new HttpGet("https://example.com/");

ステップ9-リクエストを実行します

を使用してリクエストを実行します execute() 方法。

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

次の例は、SSLContrextのカスタマイズを示しています。

import java.io.File;
import javax.net.ssl.SSLContext;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.conn.ssl.NoopHostnameVerifier;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
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.ssl.SSLContextBuilder;
import org.apache.http.ssl.SSLContexts;
import org.apache.http.util.EntityUtils;

public class ClientCustomSSL {
   
   public final static void main(String[] args) throws Exception {

      //Creating SSLContextBuilder object
      SSLContextBuilder SSLBuilder = SSLContexts.custom();
  
      //Loading the Keystore file
      File file = new File("mykeystore.jks");
      SSLBuilder = SSLBuilder.loadTrustMaterial(file,
         "changeit".toCharArray());

      //Building the SSLContext usiong the build() method
      SSLContext sslcontext = SSLBuilder.build();
 
      //Creating SSLConnectionSocketFactory object
      SSLConnectionSocketFactory sslConSocFactory = new SSLConnectionSocketFactory(sslcontext, new NoopHostnameVerifier());
 
      //Creating HttpClientBuilder
      HttpClientBuilder clientbuilder = HttpClients.custom();

      //Setting the SSLConnectionSocketFactory
      clientbuilder = clientbuilder.setSSLSocketFactory(sslConSocFactory);

      //Building the CloseableHttpClient
      CloseableHttpClient httpclient = clientbuilder.build();
      
      //Creating the HttpGet request
      HttpGet httpget = new HttpGet("https://example.com/");
 
      //Executing the request
      HttpResponse httpresponse = httpclient.execute(httpget);

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

      //Retrieving the HttpEntity and displaying the no.of bytes read
      HttpEntity entity = httpresponse.getEntity();
      if (entity != null) {
         System.out.println(EntityUtils.toByteArray(entity).length);
      } 
   }
}

出力

上記のプログラムを実行すると、次の出力が生成されます。

HTTP/1.1 200 OK
1270

HttpClientを使用すると、マルチパートアップロードを実行できます。つまり、大きなオブジェクトを小さなパーツにアップロードできます。この章では、単純なテキストファイルをアップロードすることにより、HTTPクライアントでのマルチパートアップロードについて説明します。

一般に、マルチパートアップロードには3つのパートが含まれます。

  • アップロードの開始

  • オブジェクトパーツのアップロード

  • マルチパートアップロードの完了

HttpClientを使用したマルチパートアップロードの場合、以下の手順に従う必要があります-

  • マルチパートビルダーを作成します。

  • 必要なパーツを追加します。

  • ビルドを完了し、マルチパートHttpEntityを取得します。

  • 上記のマルチパートエンティティを設定して、リクエストを作成します。

  • リクエストを実行します。

以下は、HttpClientライブラリを使用してマルチパートエンティティをアップロードする手順です。

ステップ1-HttpClientオブジェクトを作成する

ザ・ createDefault() の方法 HttpClients クラスはクラスのオブジェクトを返します CloseableHttpClient、これはHttpClientインターフェイスの基本実装です。このメソッドを使用して、HttpClientオブジェクトを作成します-

//Creating CloseableHttpClient object
CloseableHttpClient httpclient = HttpClients.createDefault();

ステップ2-FileBodyオブジェクトを作成する

FileBodyclassは、ファイルに裏打ちされたバイナリ本体部分を表します。を渡すことによってこのクラスをインスタンス化しますFile オブジェクトと ContentType コンテンツのタイプを表すオブジェクト。

//Creating a File object
File file = new File("sample.txt");

//Creating the FileBody object
FileBody filebody = new FileBody(file, ContentType.DEFAULT_BINARY);

ステップ3-MultipartEntityBuilderを作成する

ザ・ MultipartEntityBuilder クラスはマルチパートを構築するために使用されます HttpEntityオブジェクト。を使用してオブジェクトを作成しますcreate() (同じクラスの)メソッド。

//Creating the MultipartEntityBuilder
MultipartEntityBuilder entitybuilder = MultipartEntityBuilder.create();

ステップ4-モードを設定する

A MultipartEntityBuilderSTRICT、RFC6532、およびBROWSER_COMPATIBLEの3つのモードがあります。を使用して目的のモードに設定しますsetMode() 方法。

//Setting the mode
entitybuilder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);

ステップ5-さまざまな必要なパーツを追加します

メソッドの使用 addTextBody()、addPart()および、 addBinaryBody()、単純なテキスト、ファイル、ストリーム、およびその他のオブジェクトをに追加できます MultipartBuilder。これらの方法を使用して、必要なコンテンツを追加します。

//Adding text
entitybuilder.addTextBody("sample_text", "This is the text part of our file");
//Adding a file
entitybuilder.addBinaryBody("image", new File("logo.png"));

ステップ6-単一のエンティティを構築する

これらすべてのパーツを使用して、単一のエンティティに構築できます。 build() の方法 MultipartEntityBuilderクラス。この方法を使用して、すべてのパーツを1つに構築しますHttpEntity

//Building a single entity using the parts
HttpEntity mutiPartHttpEntity = entityBuilder.build();

ステップ7-RequestBuilderオブジェクトを作成する

クラス RequestBuilderパラメータを追加してリクエストを作成するために使用されます。リクエストのタイプがPUTまたはPOSTの場合、URLエンコードされたエンティティとしてパラメータをリクエストに追加します。

を使用して(POSTタイプの)RequestBuilderオブジェクトを作成します。 post()方法。そして、リクエストを送信したいURIをパラメータとして渡します。

//Building the post request object
RequestBuilder reqbuilder = RequestBuilder.post("http://httpbin.org/post");

ステップ8-エンティティオブジェクトをRequestBuilderに設定します

上記で作成したマルチパートエンティティを、を使用してRequestBuilderに設定します。 setEntity() の方法 RequestBuilder クラス。

//Setting the entity object to the RequestBuilder
reqbuilder.setEntity(mutiPartHttpEntity);

ステップ9-HttpUriRequestをビルドします

を建てる HttpUriRequest を使用してオブジェクトをリクエストする build() の方法 RequestBuilder クラス。

//Building the request
HttpUriRequest multipartRequest = reqbuilder.build();

ステップ10-リクエストを実行する

を使用して execute() メソッドで、前のステップで作成されたリクエストを実行します(このメソッドへのパラメーターとしてリクエストをバイパスします)。

//Executing the request
HttpResponse httpresponse = httpclient.execute(multipartRequest);

次の例は、HttpClientライブラリを使用してマルチパートリクエストを送信する方法を示しています。この例では、ファイルに裏打ちされたマルチパートリクエストを送信しようとしています。

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpUriRequest;
import org.apache.http.client.methods.RequestBuilder;
import org.apache.http.entity.ContentType;
import org.apache.http.entity.mime.HttpMultipartMode;
import org.apache.http.entity.mime.MultipartEntityBuilder;
import org.apache.http.entity.mime.content.FileBody;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import java.io.File;
import java.io.IOException;
import java.net.URISyntaxException;

public class MultipartUploadExample {
 
   public static void main(String args[]) throws Exception{

      //Creating CloseableHttpClient object
      CloseableHttpClient httpclient = HttpClients.createDefault();
 
      //Creating a file object
      File file = new File("sample.txt");

      //Creating the FileBody object
      FileBody filebody = new FileBody(file, ContentType.DEFAULT_BINARY);

      //Creating the MultipartEntityBuilder
      MultipartEntityBuilder entitybuilder = MultipartEntityBuilder.create();

      //Setting the mode
      entitybuilder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);

      //Adding text
      entitybuilder.addTextBody("sample_text", "This is the text part of our file");

      //Adding a file
      entitybuilder.addBinaryBody("image", new File("logo.png"));

      //Building a single entity using the parts
      HttpEntity mutiPartHttpEntity = entitybuilder.build();

      //Building the RequestBuilder request object
      RequestBuilder reqbuilder = RequestBuilder.post("http://httpbin.org/post");

      //Set the entity object to the RequestBuilder
      reqbuilder.setEntity(mutiPartHttpEntity);

      //Building the request
      HttpUriRequest multipartRequest = reqbuilder.build();

      //Executing the request
      HttpResponse httpresponse = httpclient.execute(multipartRequest);

      //Printing the status and the contents of the response
      System.out.println(EntityUtils.toString(httpresponse.getEntity()));
      System.out.println(httpresponse.getStatusLine());
   }
}

出力

上記のプログラムを実行すると、次の出力が生成されます。

{
   "args": {},
   "data": "",
   "files": {
      "image": "data:application/octets66PohrH3IWNk1FzpohfdXPIfv9X3490FGcuXsHn9X0piCwomF/xdgADZ9GsfSyvLYAAAAAE
      lFTkSuQmCC"
   },
   "form": {
      "sample_text": "This is the text part of our file"
   },
   "headers": {
      "Accept-Encoding": "gzip,deflate",
      "Connection": "close",
      "Content-Length": "11104", 
      "Content-Type": "multipart/form-data;
      boundary=UFJbPHT7mTwpVq70LpZgCi5I2nvxd1g-I8Rt",
      "Host": "httpbin.org",
      "User-Agent": "Apache-HttpClient/4.5.6 (Java/1.8.0_91)"
   },
   "json": null,
   "origin": "117.216.245.180",
   "url": "http://httpbin.org/post"
}
HTTP/1.1 200 OK