Apache HttpClient-빠른 가이드

HTTP (Hypertext Transfer Protocol)는 분산 된 협업 하이퍼 미디어 정보 시스템을위한 애플리케이션 수준 프로토콜입니다. 이것은 1990 년 이후 World Wide Web (즉, 인터넷)을위한 데이터 통신의 기반입니다. HTTP는 요청 메서드, 오류 코드 및 헤더의 확장을 사용하여 다른 목적으로 사용할 수있는 일반 및 상태 비 저장 프로토콜입니다.

기본적으로 HTTP는 TCP / IP 기반 통신 프로토콜로, World Wide Web에서 데이터 (HTML 파일, 이미지 파일, 쿼리 결과 등)를 전달하는 데 사용됩니다. 기본 포트는 TCP 80이지만 다른 포트도 사용할 수 있습니다. 컴퓨터가 서로 통신 할 수있는 표준화 된 방법을 제공합니다. HTTP 사양은 클라이언트의 요청 데이터가 구성되어 서버로 전송되는 방법과 서버가 이러한 요청에 응답하는 방법을 정의합니다.

Http 클라이언트 란?

Http 클라이언트는 전송 라이브러리이며 클라이언트 측에 있으며 HTTP 메시지를 보내고받습니다. 최신 HTTP 표준을 충족하는 최신 기능이 풍부하고 효율적인 구현을 제공합니다.

클라이언트 라이브러리를 사용하는 것 외에도 웹 브라우저, 웹 서비스 클라이언트 등과 같은 HTTP 기반 애플리케이션을 구축 할 수 있습니다.

Http 클라이언트의 기능

다음은 Http 클라이언트의 눈에 띄는 기능입니다-

  • HttpClient 라이브러리는 사용 가능한 모든 HTTP 메서드를 구현합니다.

  • HttpClient 라이브러리는 Secure Socket Layer 프로토콜을 사용하여 요청을 보호하는 API를 제공합니다.

  • HttpClient를 사용하면 프록시를 사용하여 연결을 설정할 수 있습니다.

  • Basic, Digest, NTLMv1, NTLMv2, NTLM2 Session 등과 같은 인증 체계를 사용하여 연결을 인증 할 수 있습니다.

  • HttpClient 라이브러리는 여러 스레드를 통한 요청 전송을 지원합니다. 다양한 스레드에서 설정된 여러 연결을 관리합니다.ClientConnectionPoolManager.

  • Apache HttpClient 라이브러리를 사용하여 연결 시간 제한을 설정할 수 있습니다.

이 장에서는 Eclipse IDE에서 HttpClient 환경을 설정하는 방법을 설명합니다. 설치를 진행하기 전에 시스템에 이미 Eclipse가 설치되어 있는지 확인하십시오. 그렇지 않은 경우 Eclipse를 다운로드하여 설치하십시오.

Eclipse에 대한 자세한 내용은 Eclipse Tutorial을 참조하십시오 .

1 단계-종속성 JAR 파일 다운로드

HttpClient (컴포넌트) 웹 사이트 의 공식 홈페이지 를 열고 다운로드 페이지로 이동합니다.

그런 다음 최신 안정 버전을 다운로드하십시오. 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 get 요청 메소드를 나타냅니다.

HttpClient 라이브러리를 사용하여 가져 오기 요청을 보내려면 아래 단계를 따르십시오.

1 단계-HttpClient 개체 만들기

그만큼 createDefault() 의 방법 HttpClients 클래스는 CloseableHttpClient 의 기본 구현입니다. HttpClient 상호 작용.

이 방법을 사용하여 아래와 같이 HttpClient 객체를 만듭니다.

CloseableHttpClient httpclient = HttpClients.createDefault();

2 단계-HttpGet 개체 만들기

그만큼 HttpGet 클래스는 URI를 사용하여 주어진 서버의 정보를 검색하는 HTTPGET 요청을 나타냅니다.

이 클래스를 인스턴스화하여 HTTP GET 요청을 만듭니다. 이 클래스의 생성자는 URI를 나타내는 String 값을받습니다.

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

3 단계-Get 요청 실행

그만큼 execute() 의 방법 CloseableHttpClient 클래스는 HttpUriRequest (인터페이스) 개체 (예 : HttpGet, HttpPost, HttpPut, HttpHead 등)를 받아들이고 응답 개체를 반환합니다.

다음과 같이이 방법을 사용하여 요청을 실행하십시오.

HttpResponse httpresponse = httpclient.execute(httpget);

다음은 HttpClient 라이브러리를 사용하여 HTTP GET 요청을 실행하는 예입니다.

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 라이브러리를 사용하여 HTTP POST 요청을 보내려면 아래 단계를 따르십시오.

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 라이브러리를 사용하여 HTTP POST 요청을 실행하는 예입니다.

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를 사용하여 주어진 서버의 정보를 검색하는 HTTP GET 요청을 나타냅니다.

HttpGet 클래스를 인스턴스화하고 URI를 나타내는 문자열을 해당 생성자에 매개 변수로 전달하여 HttpGet 요청을 만듭니다.

ResponseHandler<String> responseHandler = new MyResponseHandler();

4 단계-응답 핸들러를 사용하여 Get 요청 실행

그만큼 CloseableHttpClient 클래스에는 다음과 같은 변형이 있습니다. execute() 두 개의 객체를받는 방법 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를 사용하여 주어진 서버의 정보를 검색하는 HTTP GET 요청을 나타냅니다.

URI를 나타내는 문자열을 전달하여 HttpGet 클래스를 인스턴스화하여 HTTP GET 요청을 만듭니다.

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 내에 중첩 됨)을 시작하고이 try 블록의 프로그램에 나머지 코드를 작성한 다음 finally 블록에서 HttpResponse 개체를 닫습니다.

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

요청, 응답 스트림 등과 같은 객체를 생성 / 얻을 때마다 다음 줄에서 try finally 블록을 시작하고, 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() 즉,이 메서드를 호출 한 후 특정 요청에 대해 실행이 중단됩니다.

이 메서드가 한 번 실행 된 후에 호출되면 해당 실행의 응답이 영향을받지 않고 후속 실행이 중단됩니다.

다음 예를 살펴보면 HttpGet 요청을 만들고 다음을 사용하여 요청 형식을 인쇄했습니다. getMethod().

그런 다음 동일한 요청으로 다른 실행을 수행했습니다. 다시 첫 번째 실행을 사용하여 상태 줄을 인쇄 했습니다. 마지막으로 두 번째 실행의 상태 줄을 인쇄했습니다.

논의 된 바와 같이, 첫 번째 실행 (중단 메소드 이전 실행) 의 응답 이 인쇄되고 (중단 메소드 이후에 기록 된 두 번째 상태 행 포함), abort 메소드 이후 현재 요청의 모든 후속 실행이 실패합니다. 예외.

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 요청 객체를 생성하고 샘플 헤더, 데모 헤더 및 테스트 헤더의 세 가지 헤더를 추가했습니다.

에서 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();

이 개체를 사용하여 평소와 같이 요청 실행을 수행 할 수 있습니다.

다음 예제는 응답 인터셉터의 사용법을 보여줍니다. 이 예에서는 프로세서의 응답에 샘플 헤더, 데모 헤더 및 테스트 헤더의 세 가지 헤더를 추가했습니다.

요청을 실행하고 응답을받은 후에는 다음을 사용하여 응답의 모든 헤더 이름을 인쇄했습니다. getAllHeaders() 방법.

출력에서 목록에있는 세 개의 헤더 이름을 볼 수 있습니다.

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를 사용하면 사용자 이름과 비밀번호가 필요한 웹 사이트에 연결할 수 있습니다. 이 장에서는 사용자 이름과 암호를 요청하는 사이트에 대해 클라이언트 요청을 실행하는 방법에 대해 설명합니다.

1 단계-CredentialsProvider 개체 만들기

그만큼 CredentialsProvider인터페이스는 사용자 로그인 자격 증명을 보관하기 위해 컬렉션을 유지합니다. 개체를 인스턴스화하여 만들 수 있습니다.BasicCredentialsProvider 클래스,이 인터페이스의 기본 구현.

CredentialsProvider credentialsPovider = new BasicCredentialsProvider();

2 단계-자격 증명 설정

다음을 사용하여 CredentialsProvider 개체에 필요한 자격 증명을 설정할 수 있습니다. setCredentials() 방법.

이 방법은 아래와 같이 두 개의 객체를받습니다.

  • 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 개체를 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 만들기

인스턴스화하여 HTTP GET 요청을 만듭니다. HttpGet 수업.

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

6 단계-요청 실행

의 변종 중 하나 execute() 방법은 HttpHostHttpRequest개체 및 요청을 실행합니다. 이 방법을 사용하여 요청 실행-

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

다음 예제는 프록시를 통해 HTTP 요청을 서버에 보내는 방법을 보여줍니다. 이 예에서는 localhost를 통해 google.com에 HTTP GET 요청을 보냅니다. 응답 헤더와 응답 본문을 인쇄했습니다.

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()방법. 이 방법은 두 개의 객체를받습니다.

  • 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 요청 개체를 만들고 구성 개체를 설정합니다.

만들기 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 () 메서드를 사용하여 RequestBuilder 객체 (POST 유형)를 만듭니다.

//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 개체의 실행 메서드는 HttpUriRequest (인터페이스) 개체 (예 : HttpGet, HttpPost, HttpPut, HttpHead 등)를 받아들이고 응답 개체를 반환합니다.

이전 단계에서 생성 한 HttpUriRequest를 execute() 방법.

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

다음 예제는 로그인 자격 증명을 전송하여 양식에 로그온하는 방법을 보여줍니다. 여기에 두 개의 매개 변수를 보냈습니다.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

쿠키를 사용한 양식 로그인

양식에 쿠키가 저장되어있는 경우 기본값을 만드는 대신 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 요청을 전달하여 위에 지정된 객체.

페이지에 쿠키가 저장되어있는 경우 전달한 매개 변수가 쿠키 저장소에 추가됩니다.

당신은의 내용을 인쇄 할 수 있습니다 CookieStore 매개 변수를 볼 수있는 객체입니다 (이전 매개 변수와 함께 페이지가 케이스에 저장).

쿠키를 인쇄하려면 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는 쿠키를 만들고 관리 할 수있는 쿠키를 지원합니다.

쿠키 생성

HttpClient 라이브러리를 사용하여 쿠키를 생성하려면 아래 단계를 따르십시오.

1 단계-Cookiestore 객체 생성

그만큼 CookieStore인터페이스는 Cookie 개체의 추상 저장소를 나타냅니다. 다음을 인스턴스화하여 쿠키 저장소를 만들 수 있습니다.BasicCookieStore 클래스,이 인터페이스의 기본 구현.

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

2 단계-ClientCookie 개체 만들기

쿠키의 기능 외에도 ClientCookie는 서버에서 원래 쿠키를 가져올 수 있습니다. 다음을 인스턴스화하여 클라이언트 쿠키를 만들 수 있습니다.BasicClientCookie수업. 이 클래스의 생성자에 특정 쿠키에 저장하려는 키-값 쌍을 전달해야합니다.

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

3 단계-쿠키에 값 설정

클라이언트 쿠키에 대해 각각의 방법을 사용하여 경로, 값, 버전, 만료 날짜, 도메인, 설명 및 속성을 설정 / 제거 할 수 있습니다.

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 단계-쿠키 저장소에 쿠키 추가

다음을 사용하여 쿠키 저장소에 쿠키를 추가 할 수 있습니다. addCookie() 의 방법 BasicCookieStore 수업.

필요한 쿠키를 Cookiestore.

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

다음 예제는 쿠키를 만들고 쿠키 저장소에 추가하는 방법을 보여줍니다. 여기에서 도메인 및 경로 값을 설정하여 쿠키 저장소, 쿠키 묶음을 만들고 쿠키 저장소에 추가했습니다.

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

쿠키 검색

다음을 사용하여 쿠키 저장소에 쿠키를 추가 할 수 있습니다. getCookies() 의 방법 asicCookieStore수업. 이 메서드는 쿠키 저장소의 모든 쿠키를 보유하는 목록을 반환합니다.

아래와 같이 반복자를 사용하여 쿠키 저장소의 내용을 인쇄 할 수 있습니다.

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

다음 예제는 쿠키 저장소에서 쿠키를 검색하는 방법을 보여줍니다. 여기서는 쿠키 저장소에 여러 쿠키를 추가하고 다시 검색합니다.

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]

다중 스레드 프로그램에는 동시에 실행할 수있는 두 개 이상의 부분이 포함되어 있으며 각 부분은 사용 가능한 리소스를 최적으로 사용하여 동시에 다른 작업을 처리 할 수 ​​있습니다.

다중 스레드 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 단계-실행 방법 구현

클래스를 만들고 스레드로 만들고 (스레드 클래스를 확장하거나 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를 사용하여 주어진 서버의 정보를 검색하는 HTTP GET 요청을 나타냅니다.

URI를 나타내는 문자열을 전달하여 HttpGet 클래스를 인스턴스화하여 HTTP GET 요청을 만듭니다.

//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 클라이언트에서 멀티 파트 업로드를 시연합니다.

일반적으로 모든 멀티 파트 업로드에는 세 부분이 포함됩니다.

  • 업로드 시작

  • 개체 부분 업로드

  • 멀티 파트 업로드 완료

HttpClient를 사용한 멀티 파트 업로드의 경우 다음 단계를 따라야합니다.

  • 멀티 파트 빌더를 만듭니다.

  • 원하는 부분을 추가하십시오.

  • 빌드를 완료하고 멀티 파트 HttpEntity를 얻습니다.

  • 위의 muti-part 엔티티를 설정하여 요청을 작성하십시오.

  • 요청을 실행하십시오.

다음은 HttpClient 라이브러리를 사용하여 멀티 파트 엔티티를 업로드하는 단계입니다.

1 단계-HttpClient 개체 만들기

그만큼 createDefault() 의 방법 HttpClients 클래스는 클래스의 객체를 반환합니다. CloseableHttpClient, HttpClient 인터페이스의 기본 구현입니다. 이 방법을 사용하여 HttpClient 객체를 만듭니다-

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

2 단계-FileBody 개체 만들기

FileBody클래스는 파일이 지원하는 이진 본문 부분을 나타냅니다. 전달하여이 클래스를 인스턴스화하십시오.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 단계-모드 설정

MultipartEntityBuilderSTRICT, RFC6532 및 BROWSER_COMPATIBLE의 세 가지 모드가 있습니다. 버튼을 사용하여 원하는 모드로 설정하십시오.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수업. 이 방법을 사용하여 모든 부품을 단일HttpEntity.

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

7 단계-RequestBuilder 객체 생성

클래스 RequestBuilder매개 변수를 추가하여 요청을 작성하는 데 사용됩니다. 요청이 PUT 또는 POST 유형 인 경우 매개 변수를 URL 인코딩 엔티티로 요청에 추가합니다.

다음을 사용하여 RequestBuilder 객체 (POST 유형)를 만듭니다. 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