अपाचे HttpClient - त्वरित गाइड

हाइपरटेक्स्ट ट्रांसफर प्रोटोकॉल (HTTP) वितरित, सहयोगी, हाइपरमीडिया सूचना प्रणाली के लिए एक अनुप्रयोग-स्तरीय प्रोटोकॉल है। यह 1990 के बाद से वर्ल्ड वाइड वेब (यानी, इंटरनेट) के लिए डेटा संचार की नींव है। HTTP एक सामान्य और स्टेटलेस प्रोटोकॉल है, जिसका उपयोग अन्य उद्देश्यों के साथ-साथ अपने अनुरोध विधियों, त्रुटि कोड और हेडर के एक्सटेंशन का उपयोग करने के लिए किया जा सकता है।

मूल रूप से, HTTP एक टीसीपी / आईपी आधारित संचार प्रोटोकॉल है, जिसका उपयोग वर्ल्ड वाइड वेब पर डेटा (HTML फ़ाइलें, छवि फ़ाइलें, क्वेरी परिणाम आदि) देने के लिए किया जाता है। डिफ़ॉल्ट पोर्ट TCP 80 है, लेकिन अन्य पोर्ट का भी उपयोग किया जा सकता है। यह कंप्यूटरों को एक दूसरे के साथ संवाद करने के लिए एक मानकीकृत तरीका प्रदान करता है। HTTP विनिर्देशन परिभाषित करता है कि ग्राहकों के अनुरोध डेटा का निर्माण और सर्वर को कैसे भेजा जाएगा, और सर्वर इन अनुरोधों का जवाब कैसे देते हैं।

Http क्लाइंट क्या है

Http क्लाइंट एक ट्रांसफर लाइब्रेरी है, यह क्लाइंट मैसेज पर रहता है, HTTP मैसेज भेजता है और प्राप्त करता है। यह अद्यतित, सुविधा संपन्न और कुशल कार्यान्वयन प्रदान करता है जो हाल के HTTP मानकों को पूरा करता है।

क्लाइंट लाइब्रेरी का उपयोग करने के अलावा, व्यक्ति वेब आधारित ब्राउज़र, वेब सेवा क्लाइंट आदि जैसे HTTP आधारित अनुप्रयोगों का निर्माण कर सकता है।

Http क्लाइंट की विशेषताएं

Http क्लाइंट की प्रमुख विशेषताएं निम्नलिखित हैं -

  • HttpClient पुस्तकालय सभी उपलब्ध HTTP विधियों को लागू करता है।

  • HttpClient पुस्तकालय सिक्योर सॉकेट लेयर प्रोटोकॉल का उपयोग करके अनुरोधों को सुरक्षित करने के लिए एपीआई प्रदान करता है।

  • HttpClient का उपयोग करके, आप प्रॉक्सी का उपयोग करके कनेक्शन स्थापित कर सकते हैं।

  • आप मूल, डाइजेस्ट, NTLMv1, NTLMv2, NTLM2 सत्र आदि जैसे प्रमाणीकरण योजनाओं का उपयोग करके कनेक्शन प्रमाणित कर सकते हैं।

  • HttpClient पुस्तकालय कई थ्रेड्स के माध्यम से अनुरोध भेजने का समर्थन करता है। यह विभिन्न धागों से स्थापित कई कनेक्शनों का उपयोग करता हैClientConnectionPoolManager

  • Apache HttpClient लाइब्रेरी का उपयोग करके, आप कनेक्शन टाइमआउट सेट कर सकते हैं।

इस अध्याय में, हम बताएंगे कि ग्रहण आईडीई में HttpClient के लिए वातावरण कैसे सेट करें। स्थापना के साथ आगे बढ़ने से पहले, सुनिश्चित करें कि आपके पास पहले से ही आपके सिस्टम में ग्रहण स्थापित है। यदि नहीं, तो ग्रहण डाउनलोड और इंस्टॉल करें।

ग्रहण के बारे में अधिक जानकारी के लिए, कृपया हमारे ग्रहण ट्यूटोरियल को देखें ।

चरण 1 - निर्भरता JAR फ़ाइल डाउनलोड करें

HttpClient (घटकों) वेबसाइट का आधिकारिक मुखपृष्ठ खोलें और डाउनलोड पृष्ठ पर जाएं

फिर, का नवीनतम स्थिर संस्करण डाउनलोड करें HttpClient। यहां, पूरे ट्यूटोरियल के दौरान, हम 4.5.6 संस्करण का उपयोग कर रहे हैं, इसलिए फ़ाइल डाउनलोड करें4.5.6.zip

डाउनलोड किए गए फ़ोल्डर के भीतर, आपको नाम का एक फ़ोल्डर मिलेगा lib और इसमें जर्ट की आवश्यक फाइलें शामिल हैं, जो आपके प्रोजेक्ट के क्लासपाथ में जोड़ी जाएंगी, ताकि HttpClient के साथ काम किया जा सके।

चरण 2 - एक प्रोजेक्ट बनाएं और बिल्ड पथ सेट करें

ग्रहण खोलें और एक नमूना परियोजना बनाएं। प्रोजेक्ट पर राइट क्लिक ऑप्शन को चुनेंBuild Path → Configure Build Path जैसा की नीचे दिखाया गया।

में Java Build Path में फ्रेम Libraries टैब पर क्लिक करें Add External JARs

और लिबर फोल्डर में सभी जार फाइलों को चुनें और, पर क्लिक करें Apply and Close

आप ग्रहण में HttpClient पुस्तकालय के साथ काम करने के लिए पूरी तरह तैयार हैं।

GET विधि का उपयोग किसी दिए गए URI का उपयोग करके दिए गए सर्वर से जानकारी प्राप्त करने के लिए किया जाता है। GET का उपयोग करने वाले अनुरोधों को केवल डेटा पुनर्प्राप्त करना चाहिए और डेटा पर कोई अन्य प्रभाव नहीं होना चाहिए।

HttpClient एपीआई नाम की एक कक्षा प्रदान करता है HttpGet जो प्राप्त अनुरोध विधि का प्रतिनिधित्व करता है।

HttpClient लाइब्रेरी का उपयोग करके अनुरोध प्राप्त करने के लिए नीचे दिए गए चरणों का पालन करें

चरण 1 - एक HttpClient ऑब्जेक्ट बनाएँ

createDefault() की विधि HttpClients वर्ग रिटर्न ए CloseableHttpClient ऑब्जेक्ट, जो का आधार कार्यान्वयन है HttpClient इंटरफेस।

इस विधि का उपयोग करके, नीचे दिखाए अनुसार एक HttpClient ऑब्जेक्ट बनाएं -

CloseableHttpClient httpclient = HttpClients.createDefault();

चरण 2 - एक HttpGet ऑब्जेक्ट बनाएँ

HttpGet वर्ग HTTPGET अनुरोध का प्रतिनिधित्व करता है जो किसी URI का उपयोग करके दिए गए सर्वर की जानकारी को पुनः प्राप्त करता है।

इस श्रेणी को तत्काल बनाकर एक HTTP GET अनुरोध बनाएँ। इस वर्ग का निर्माण URI का प्रतिनिधित्व करने वाले स्ट्रिंग मूल्य को स्वीकार करता है।

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

चरण 3 - अनुरोध प्राप्त करें निष्पादित करें

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 एपीआई नाम की एक कक्षा प्रदान करता है HttpPost जो POST अनुरोध का प्रतिनिधित्व करता है।

HttpClient लाइब्रेरी का उपयोग करके HTTP POST अनुरोध भेजने के लिए नीचे दिए गए चरणों का पालन करें।

चरण 1 - एक HttpClient ऑब्जेक्ट बनाएँ

createDefault() की विधि HttpClients वर्ग कक्षा की एक वस्तु देता है CloseableHttpClient, जिसका आधार कार्यान्वयन है HttpClient इंटरफेस।

इस विधि का उपयोग करके, एक HttpClient ऑब्जेक्ट बनाएँ।

CloseableHttpClient httpClient = HttpClients.createDefault();

चरण 2 - HttpPost ऑब्जेक्ट बनाएँ

HttpPost वर्ग का प्रतिनिधित्व करता है HTTP POSTनिवेदन। यह आवश्यक डेटा भेजता है और यूआरआई का उपयोग करके दिए गए सर्वर की जानकारी को पुनः प्राप्त करता है।

इस पल को तत्काल बनाकर अनुरोध करें HttpPost URI का प्रतिनिधित्व करने वाले एक स्ट्रिंग मान को कक्षा और पास करें, इसके निर्माता के लिए एक पैरामीटर के रूप में।

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

चरण 3 - अनुरोध प्राप्त करें निष्पादित करें

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 एपीआई के रूप में जाना जाता है एक इंटरफेस प्रदान करता है 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 वर्ग HTTP GET अनुरोध का प्रतिनिधित्व करता है जो किसी URI का उपयोग करके दिए गए सर्वर की जानकारी को पुनः प्राप्त करता है।

HttpGet क्लास को तत्काल करके और उसके निर्माता को एक पैरामीटर के रूप में URI का प्रतिनिधित्व करने वाले स्ट्रिंग को पास करके एक HttpGet अनुरोध बनाएं।

ResponseHandler<String> responseHandler = new MyResponseHandler();

चरण 4 - प्रतिक्रिया हैंडलर का उपयोग करके अनुरोध प्राप्त करें

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 - एक कोशिश अंत में ब्लॉक शुरू

एक कोशिश अंत में ब्लॉक शुरू, कोशिश ब्लॉक में कार्यक्रमों में शेष कोड लिखें और अंत में ब्लॉक में CloseableHttpClient ऑब्जेक्ट को बंद करें।

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

चरण 3 - एक HttpGetobject बनाएँ

HttpGet वर्ग HTTP GET अनुरोध का प्रतिनिधित्व करता है जो किसी URI का उपयोग करके दिए गए सर्वर की जानकारी को पुनः प्राप्त करता है।

URI का प्रतिनिधित्व करने वाले एक स्ट्रिंग को पास करके HttpGet क्लास को इंस्टेंट करके एक HTTP GET अनुरोध बनाएं।

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

चरण 4 - अनुरोध प्राप्त करें निष्पादित करें

execute() की विधि CloseableHttpClient ऑब्जेक्ट स्वीकार करता है HttpUriRequest (इंटरफ़ेस) ऑब्जेक्ट (यानी HttpGet, HttpPost, HttpPut, HttpHead आदि) और एक प्रतिक्रिया ऑब्जेक्ट देता है।

दी गई विधि का उपयोग करके अनुरोध को निष्पादित करें -

HttpResponse httpResponse = httpclient.execute(httpGet);

चरण 5 - दूसरा (नेस्टेड) ​​प्रयास अंत में शुरू करें

एक और कोशिश-अंत ब्लॉक शुरू करें (पिछले प्रयास के अंत में नेस्टेड), इस कोशिश ब्लॉक में कार्यक्रमों में शेष कोड लिखें और अंततः ब्लॉक में HttpResponse ऑब्जेक्ट को बंद करें।

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

उदाहरण

जब भी आप अनुरोध, प्रतिक्रिया स्ट्रीम आदि जैसे ऑब्जेक्ट बनाते / प्राप्त करते हैं, तो अगली पंक्ति में एक कोशिश अंत में शुरू करें, कोशिश के भीतर शेष कोड लिखें और संबंधित ऑब्जेक्ट को अंत में ब्लॉक में बंद करें जैसा कि निम्नलिखित कार्यक्रम में दिखाया गया है -

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()

फिर, हमने उसी अनुरोध के साथ एक और निष्पादन किया है। फिर से 1 सेंट निष्पादन का उपयोग करके स्थिति रेखा मुद्रित की गई। अंत में, दूसरी निष्पादन की स्थिति रेखा को मुद्रित किया।

जैसा कि चर्चा की गई है, 1 सेंट निष्पादन (गर्भपात विधि से पहले निष्पादन) की प्रतिक्रियाओं को मुद्रित किया जाता है (गर्भपात विधि के बाद लिखी गई दूसरी स्थिति लाइन सहित) और, गर्भपात विधि विफल होने के बाद वर्तमान अनुरोध के सभी बाद के निष्पादन विफल हो जाते हैं। अपवाद।

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 ऊपर बनाया गया इंटरसेप्टर जोड़कर वस्तु, जैसा कि नीचे दिखाया गया है -

//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इंटरफ़ेस उपयोगकर्ता लॉगिन क्रेडेंशियल्स रखने के लिए एक संग्रह रखता है। आप झटपट अपनी वस्तु बना सकते हैंBasicCredentialsProvider वर्ग, इस इंटरफ़ेस का डिफ़ॉल्ट कार्यान्वयन।

CredentialsProvider credentialsPovider = new BasicCredentialsProvider();

चरण 2 - क्रेडेंशियल्स सेट करें

आप क्रेडेंशियलप्रोवाइडर ऑब्जेक्ट का उपयोग करके आवश्यक क्रेडेंशियल्स सेट कर सकते हैं 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 - क्रेडेंशियल्सपॉइडर सेट करें

आप एक बनाया HttpClientBuilder का उपयोग करके ऊपर बनाई गई क्रेडेंशियल्सPovider ऑब्जेक्ट सेट कर सकते हैं setDefaultCredentialsProvider() तरीका।

क्लाइंट बिल्डर को पिछले चरण में बनाए गए क्रेडेंशियलप्रॉइडर ऑब्जेक्ट को इसे पास करके सेट करें CredentialsProvider object() नीचे दिखाए अनुसार विधि।

clientbuilder = clientbuilder.setDefaultCredentialsProvider(credsProvider);

चरण 5 - क्लोज़ेबल हेटप्लिएंट बनाएँ

का निर्माण 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() विधि एक स्वीकार करता है HttpHost तथा HttpRequestऑब्जेक्ट और अनुरोध निष्पादित करता है। इस विधि का उपयोग करके अनुरोध निष्पादित करें -

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

उदाहरण

निम्न उदाहरण प्रदर्शित करता है कि प्रॉक्सी के माध्यम से सर्वर पर HTTP अनुरोध कैसे भेजा जाए। इस उदाहरण में, हम लोकलहोस्ट के माध्यम से 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 इंटरफ़ेस उपयोगकर्ता लॉगिन क्रेडेंशियल्स रखने के लिए एक संग्रह रखता है। आप BasicCredentialsProvider वर्ग, इस इंटरफ़ेस के डिफ़ॉल्ट कार्यान्वयन को तत्काल करके अपनी वस्तु बना सकते हैं।

CredentialsProvider credentialsPovider = new BasicCredentialsProvider();

चरण 2 - क्रेडेंशियल्स सेट करें

आप क्रेडेंशियलप्रोवाइडर ऑब्जेक्ट का उपयोग करके आवश्यक क्रेडेंशियल्स सेट कर सकते हैं 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 - क्रेडेंशियलपॉइडर सेट करें

आप का उपयोग कर एक HttpClientBuilder वस्तु के लिए क्रेडेंशियलप्रॉइडर ऑब्जेक्ट सेट कर सकते हैं setDefaultCredentialsProvider()तरीका। पहले बनाए गए पास करेंCredentialsProvider इस विधि पर आपत्ति।

clientbuilder = clientbuilder.setDefaultCredentialsProvider(credsProvider);

चरण 5 - क्लोज़ेबल हेटप्लिएंट बनाएँ

का निर्माण 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()तरीका। पहले बनाई गई प्रॉक्सीहोस्ट ऑब्जेक्ट को सेट करें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 एनकोडेड इकाई के रूप में अनुरोध में पैरामीटर जोड़ता है

पोस्ट () विधि का उपयोग करके एक RequestBuilder वस्तु (प्रकार POST) बनाएँ।

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

चरण 3 - सेट करें उरी और मापदंडों को RequestBuilder।

का उपयोग करके RequestBuilder ऑब्जेक्ट के लिए URI और पैरामीटर सेट करें 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इंटरफ़ेस कुकी वस्तुओं के लिए सार स्टोर का प्रतिनिधित्व करता है। आप तुरंत इंस्टेंट करके एक कुकी स्टोर बना सकते हैं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कक्षा। यह विधि एक सूची देती है जो कुकी स्टोर में सभी कुकीज़ रखती है।

आप Iterator का उपयोग करके कुकी स्टोर की सामग्री प्रिंट कर सकते हैं जैसा कि नीचे दिखाया गया है -

//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 अनुरोध ऑब्जेक्ट बनाएँ

एक पैरामीटर के रूप में वांछित यूआरआई को उसके निर्माता को पास करके HttpGet वर्ग को तुरंत।

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

चरण 5 - रन विधि को लागू करना

सुनिश्चित करें कि आपने एक वर्ग बनाया है, इसे एक थ्रेड बनाया है (या तो थ्रेड क्लास का विस्तार करके या रननेबल इंटरफ़ेस को लागू करके) और रन विधि को लागू किया है।

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

चरण 6 - थ्रेड ऑब्जेक्ट बनाएँ

ऊपर बनाई गई थ्रेड क्लास (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 - रन विधि कार्यान्वयन

रन विधि के भीतर, अनुरोध निष्पादित करें, प्रतिक्रिया प्राप्त करें और परिणाम प्रिंट करें।

उदाहरण

उदाहरण के बाद कई थ्रेड्स से एक साथ 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

सिक्योर सॉकेट लेयर का उपयोग करके, आप क्लाइंट और सर्वर के बीच एक सुरक्षित कनेक्शन स्थापित कर सकते हैं। यह संवेदनशील जानकारी जैसे क्रेडिट कार्ड नंबर, उपयोगकर्ता नाम, पासवर्ड, पिन, आदि को सुरक्षित रखने में मदद करता है।

आप अपने स्वयं के एसएसएल संदर्भ का उपयोग करके कनेक्शन को अधिक सुरक्षित बना सकते हैं HttpClient पुस्तकालय।

HttpClient लाइब्रेरी का उपयोग करके SSLContext को अनुकूलित करने के लिए नीचे दिए गए चरणों का पालन करें -

चरण 1 - SSLContextBuilder ऑब्जेक्ट बनाएँ

SSLContextBuilderSSLContext ऑब्जेक्ट्स के लिए बिल्डर है। का उपयोग करके अपनी वस्तु बनाएँcustom() की विधि SSLContexts कक्षा।

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

चरण 2 - कीस्टोर लोड करें

राह में Java_home_directory/jre/lib/security/, आप कैस्केर्ट नामक एक फ़ाइल पा सकते हैं। इसे अपनी मुख्य स्टोर फ़ाइल के रूप में सहेजें (एक्सटेंशन .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 वर्ग HTTP GET अनुरोध का प्रतिनिधित्व करता है जो किसी URI का उपयोग करके दिए गए सर्वर की जानकारी को पुनः प्राप्त करता है।

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 - मोड सेट करें

MultipartEntityBuilderतीन मोड हैं: STRICT, RFC6532, और BROWSER_COMPATIBLE। का उपयोग कर वांछित मोड पर सेट करेंsetMode() तरीका।

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

चरण 5 - विभिन्न वांछित भागों को जोड़ें

विधियों का उपयोग करना addTextBody(), जोड़ेंपार्ट () और addBinaryBody(), आप साधारण पाठ, फ़ाइलें, स्ट्रीम और अन्य ऑब्जेक्ट जोड़ सकते हैं a 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()तरीका। और उरी को पास करें, जिसे आप अनुरोध के रूप में भेजना चाहते थे।

//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