亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Apache?HttpClient使用實(shí)例詳解

 更新時(shí)間:2025年03月26日 09:28:25   作者:kmt-碼上解決  
ApacheHttpClient是一個(gè)強(qiáng)大的Java?HTTP客戶端庫,用于發(fā)送HTTP請(qǐng)求并處理響應(yīng),HttpClients提供了多種方法來創(chuàng)建和配置HTTP客戶端實(shí)例,本文給大家介紹Apache?HttpClient使用示例詳解,感興趣的朋友一起看看吧

一、Apache HttpClient 基礎(chǔ)版

HttpClients 是 Apache HttpClient 庫中的一個(gè)工具類,用于創(chuàng)建和管理 HTTP 客戶端實(shí)例。Apache HttpClient 是一個(gè)強(qiáng)大的 Java HTTP 客戶端庫,用于發(fā)送 HTTP 請(qǐng)求并處理 HTTP 響應(yīng)。HttpClients 提供了多種方法來創(chuàng)建和配置 HTTP 客戶端實(shí)例。

以下是關(guān)于 HttpClients 的詳細(xì)講解:

1. Apache HttpClient 簡介

Apache HttpClient 是一個(gè)開源的 Java HTTP 客戶端庫,支持 HTTP/1.1 和 HTTP/2 協(xié)議。它提供了豐富的功能,例如:

  • 發(fā)送 GET、POST、PUT、DELETE 等 HTTP 請(qǐng)求。
  • 處理 HTTP 請(qǐng)求和響應(yīng)的頭部、狀態(tài)碼、實(shí)體等。
  • 支持連接池、重試機(jī)制、代理、SSL/TLS 等高級(jí)功能。

2. HttpClients 類的作用

HttpClients 是一個(gè)工廠類,用于創(chuàng)建 CloseableHttpClient 實(shí)例。CloseableHttpClient 是 HTTP 客戶端的主要接口,用于執(zhí)行 HTTP 請(qǐng)求。

HttpClients 提供了多種靜態(tài)方法來創(chuàng)建和配置 HTTP 客戶端實(shí)例,例如:

  • 創(chuàng)建默認(rèn)的 HTTP 客戶端。
  • 創(chuàng)建自定義配置的 HTTP 客戶端。
  • 創(chuàng)建支持連接池的 HTTP 客戶端。

3. HttpClients 的常用方法

(1) HttpClients.createDefault()

  • 功能: 創(chuàng)建一個(gè)默認(rèn)的 HTTP 客戶端實(shí)例。
  • 特點(diǎn)
    • 使用默認(rèn)的配置(例如連接池、重試機(jī)制等)。
    • 適合大多數(shù)簡單的 HTTP 請(qǐng)求場景。
  • 示例
CloseableHttpClient httpClient = HttpClients.createDefault();

(2) HttpClients.createSystem()

  • 功能: 創(chuàng)建一個(gè)基于系統(tǒng)屬性的 HTTP 客戶端實(shí)例。
  • 特點(diǎn)
    • 使用系統(tǒng)屬性(例如代理設(shè)置、超時(shí)時(shí)間等)來配置客戶端。
    • 適合需要與系統(tǒng)配置集成的場景。
  • 示例:
CloseableHttpClient httpClient = HttpClients.createSystem();

(3) HttpClients.custom()

  • 功能: 返回一個(gè) HttpClientBuilder 對(duì)象,用于自定義配置 HTTP 客戶端。
  • 特點(diǎn)
    • 可以設(shè)置連接池、超時(shí)時(shí)間、代理、SSL/TLS 等高級(jí)配置。
    • 適合需要精細(xì)控制的場景。
  • 示例
 CloseableHttpClient httpClient = HttpClients.custom()
     .setMaxConnTotal(100) // 最大連接數(shù)
     .setMaxConnPerRoute(10) // 每個(gè)路由的最大連接數(shù)
     .build();

4. HttpClients 的使用示例

以下是一個(gè)完整的示例,展示如何使用 HttpClients 發(fā)送 HTTP GET 請(qǐng)求并處理響應(yīng):

 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;
 import org.apache.http.util.EntityUtils;
 ?
 public class HttpClientExample {
     public static void main(String[] args) {
         // 1. 創(chuàng)建 HTTP 客戶端
         try (CloseableHttpClient httpClient = HttpClients.createDefault()) {
             // 2. 創(chuàng)建 HTTP GET 請(qǐng)求
             HttpGet request = new HttpGet("https://jsonplaceholder.typicode.com/posts/1");
 ?
             // 3. 發(fā)送請(qǐng)求并獲取響應(yīng)
             try (CloseableHttpResponse response = httpClient.execute(request)) {
                 // 4. 檢查響應(yīng)狀態(tài)碼
                 int statusCode = response.getStatusLine().getStatusCode();
                 System.out.println("Status Code: " + statusCode);
 ?
                 // 5. 獲取響應(yīng)內(nèi)容
                 String responseBody = EntityUtils.toString(response.getEntity());
                 System.out.println("Response Body: " + responseBody);
             }
         } catch (Exception e) {
             e.printStackTrace();
         }
     }
 }

5. HttpClients 的高級(jí)配置

通過 HttpClients.custom() 方法,可以自定義 HTTP 客戶端的配置。以下是一些常見的配置選項(xiàng):

(1) 連接池配置

 CloseableHttpClient httpClient = HttpClients.custom()
     .setMaxConnTotal(100) // 最大連接數(shù)
     .setMaxConnPerRoute(10) // 每個(gè)路由的最大連接數(shù)
     .build();

(2) 超時(shí)配置

 RequestConfig requestConfig = RequestConfig.custom()
     .setConnectTimeout(5000) // 連接超時(shí)時(shí)間
     .setSocketTimeout(5000) // 讀取超時(shí)時(shí)間
     .build();
 ?
 CloseableHttpClient httpClient = HttpClients.custom()
     .setDefaultRequestConfig(requestConfig)
     .build();

(3) 代理配置

 HttpHost proxy = new HttpHost("proxy.example.com", 8080);
 ?
 CloseableHttpClient httpClient = HttpClients.custom()
     .setProxy(proxy)
     .build();

(4) SSL/TLS 配置

 SSLContext sslContext = SSLContexts.custom()
     .loadTrustMaterial((chain, authType) -> true) // 信任所有證書
     .build();
 ?
 CloseableHttpClient httpClient = HttpClients.custom()
     .setSSLContext(sslContext)
     .build();

6. 注意事項(xiàng)

資源釋放CloseableHttpClientCloseableHttpResponse 都實(shí)現(xiàn)了 Closeable 接口,使用后需要關(guān)閉以釋放資源。

線程安全CloseableHttpClient 是線程安全的,可以在多線程環(huán)境中共享。

性能優(yōu)化: 使用連接池和合理的超時(shí)配置可以顯著提升性能。

7. 總結(jié)

  • HttpClients 是 Apache HttpClient 庫中的一個(gè)工具類,用于創(chuàng)建和管理 HTTP 客戶端實(shí)例。
  • 它提供了多種方法來創(chuàng)建默認(rèn)或自定義配置的 HTTP 客戶端。
  • 通過 HttpClients.custom() 方法,可以實(shí)現(xiàn)連接池、超時(shí)、代理、SSL/TLS 等高級(jí)配置。
  • 使用 Apache HttpClient 可以輕松發(fā)送 HTTP 請(qǐng)求并處理響應(yīng),是 Java 中處理 HTTP 請(qǐng)求的強(qiáng)大工具。

二、Apache HttpClient 高級(jí)版

1. HttpClients 類概述

HttpClients 是 Apache HttpClient 庫中的一個(gè)工廠類,用于創(chuàng)建和配置 CloseableHttpClient 實(shí)例。它是構(gòu)建 HTTP 客戶端的入口點(diǎn),支持高度自定義的 HTTP 請(qǐng)求處理,包括連接池管理、SSL/TLS 配置、重試機(jī)制等。

2. 核心方法與配置

2.1 創(chuàng)建默認(rèn)客戶端

CloseableHttpClient httpClient = HttpClients.createDefault();

特點(diǎn)

  • 使用默認(rèn)的配置(連接池、請(qǐng)求重試等)。
  • 適合簡單場景,但擴(kuò)展性有限。

2.2 自定義配置客戶端

通過 HttpClients.custom() 返回 HttpClientBuilder,允許精細(xì)化配置:

 CloseableHttpClient httpClient = HttpClients.custom()
     .setConnectionManager(connectionManager)  // 連接池管理
     .setDefaultRequestConfig(requestConfig)   // 請(qǐng)求超時(shí)配置
     .setRetryHandler(retryHandler)            // 請(qǐng)求重試策略
     .setProxy(proxy)                          // 代理設(shè)置
     .setSSLContext(sslContext)                // SSL/TLS 配置
     .build();

3. 高級(jí)配置詳解

3.1 連接池管理

連接池是提升性能的關(guān)鍵組件,避免頻繁創(chuàng)建和銷毀連接。

 PoolingHttpClientConnectionManager connectionManager = 
     new PoolingHttpClientConnectionManager();
 connectionManager.setMaxTotal(200);          // 最大總連接數(shù)
 connectionManager.setDefaultMaxPerRoute(20); // 每個(gè)路由(目標(biāo)主機(jī))的最大連接數(shù)
 ?
 CloseableHttpClient httpClient = HttpClients.custom()
     .setConnectionManager(connectionManager)
     .build();

3.2 超時(shí)配置

 RequestConfig requestConfig = RequestConfig.custom()
     .setConnectTimeout(5000)    // 連接建立超時(shí)時(shí)間(毫秒)
     .setSocketTimeout(10000)     // 數(shù)據(jù)傳輸超時(shí)時(shí)間(毫秒)
     .setConnectionRequestTimeout(2000) // 從連接池獲取連接的超時(shí)時(shí)間
     .build();
 ?
 CloseableHttpClient httpClient = HttpClients.custom()
     .setDefaultRequestConfig(requestConfig)
     .build();

3.3 重試機(jī)制

自動(dòng)重試失敗的請(qǐng)求(例如網(wǎng)絡(luò)波動(dòng)導(dǎo)致失敗):

 HttpRequestRetryHandler retryHandler = (exception, executionCount, context) -> {
     if (executionCount >= 3) return false; // 最大重試次數(shù)
     if (exception instanceof NoHttpResponseException) return true; // 無響應(yīng)時(shí)重試
     return false;
 };
 ?
 CloseableHttpClient httpClient = HttpClients.custom()
     .setRetryHandler(retryHandler)
     .build();

3.4 代理配置

 HttpHost proxy = new HttpHost("proxy.example.com", 8080);
 CloseableHttpClient httpClient = HttpClients.custom()
     .setProxy(proxy)
     .build();

3.5 SSL/TLS 配置

信任所有證書(僅限測試環(huán)境):

 SSLContext sslContext = SSLContexts.custom()
     .loadTrustMaterial((chain, authType) -> true) // 信任所有證書
     .build();
 ?
 CloseableHttpClient httpClient = HttpClients.custom()
     .setSSLContext(sslContext)
     .setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE) // 跳過主機(jī)名驗(yàn)證
     .build();

3.6 認(rèn)證機(jī)制

使用 Basic 認(rèn)證:

 CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
 credentialsProvider.setCredentials(
     new AuthScope("host.example.com", 80),
     new UsernamePasswordCredentials("user", "pass")
 );
 ?
 CloseableHttpClient httpClient = HttpClients.custom()
     .setDefaultCredentialsProvider(credentialsProvider)
     .build();

4. 請(qǐng)求與響應(yīng)處理

4.1 發(fā)送 GET 請(qǐng)求

 HttpGet httpGet = new HttpGet("https://api.example.com/data");
 try (CloseableHttpResponse response = httpClient.execute(httpGet)) {
     int statusCode = response.getStatusLine().getStatusCode();
     HttpEntity entity = response.getEntity();
     String content = EntityUtils.toString(entity);
     EntityUtils.consume(entity); // 確保資源釋放
 }

4.2 發(fā)送 POST 請(qǐng)求(JSON 數(shù)據(jù))

 HttpPost httpPost = new HttpPost("https://api.example.com/create");
 StringEntity jsonEntity = new StringEntity("{\"key\":\"value\"}", ContentType.APPLICATION_JSON);
 httpPost.setEntity(jsonEntity);
 ?
 try (CloseableHttpResponse response = httpClient.execute(httpPost)) {
     // 處理響應(yīng)...
 }

4.3 文件上傳(Multipart)

 HttpPost httpPost = new HttpPost("https://api.example.com/upload");
 FileBody fileBody = new FileBody(new File("path/to/file"));
 MultipartEntityBuilder builder = MultipartEntityBuilder.create()
     .addPart("file", fileBody)
     .addTextBody("comment", "File upload");
 httpPost.setEntity(builder.build());

5. 高級(jí)功能

5.1 異步請(qǐng)求

使用 HttpAsyncClients 實(shí)現(xiàn)異步非阻塞請(qǐng)求:

 CloseableHttpAsyncClient asyncClient = HttpAsyncClients.custom().build();
 asyncClient.start();
 ?
 SimpleHttpRequest request = SimpleHttpRequest.get("https://api.example.com/data");
 Future<SimpleHttpResponse> future = asyncClient.execute(request, new FutureCallback<>() {
     @Override
     public void completed(SimpleHttpResponse response) {
         System.out.println("Response: " + response.getBodyText());
     }
 ?
     @Override
     public void failed(Exception ex) {
         ex.printStackTrace();
     }
 ?
     @Override
     public void cancelled() {
         System.out.println("Request cancelled");
     }
 });

5.2 請(qǐng)求攔截器

添加自定義邏輯(如日志記錄、修改請(qǐng)求頭):

 CloseableHttpClient httpClient = HttpClients.custom()
     .addInterceptorFirst((HttpRequestInterceptor) (request, context) -> {
         request.addHeader("X-Custom-Header", "value");
         System.out.println("Request URI: " + request.getRequestLine().getUri());
     })
     .build();

5.3 Cookie 管理

自動(dòng)管理 Cookie:

 CookieStore cookieStore = new BasicCookieStore();
 CloseableHttpClient httpClient = HttpClients.custom()
     .setDefaultCookieStore(cookieStore)
     .build();

6. 最佳實(shí)踐與常見問題

6.1 資源釋放

確保關(guān)閉 CloseableHttpClientCloseableHttpResponse

 try (CloseableHttpClient httpClient = HttpClients.createDefault()) {
     try (CloseableHttpResponse response = httpClient.execute(request)) {
         // 處理響應(yīng)...
     }
 }

6.2 性能調(diào)優(yōu)

  • 連接池參數(shù):根據(jù)并發(fā)需求調(diào)整 MaxTotalDefaultMaxPerRoute
  • 超時(shí)設(shè)置:避免因網(wǎng)絡(luò)問題導(dǎo)致線程阻塞。
  • 重用連接:復(fù)用 HttpClient 實(shí)例而非頻繁創(chuàng)建。

6.3 錯(cuò)誤處理

  • 重試策略:針對(duì)可恢復(fù)錯(cuò)誤(如超時(shí))配置自動(dòng)重試。
  • 異常捕獲:處理 IOExceptionClientProtocolException 等。

6.4 安全性

  • 生產(chǎn)環(huán)境禁用信任所有證書:使用有效 CA 簽名的證書。
  • 敏感信息保護(hù):避免在日志中打印請(qǐng)求頭或響應(yīng)體中的敏感數(shù)據(jù)。

7. 典型應(yīng)用場景

  • 微服務(wù)間通信:在分布式系統(tǒng)中通過 HTTP 調(diào)用其他服務(wù)。
  • API 集成:調(diào)用第三方 RESTful API(如支付網(wǎng)關(guān)、地圖服務(wù))。
  • 爬蟲開發(fā):抓取網(wǎng)頁內(nèi)容并解析數(shù)據(jù)。
  • 文件傳輸:上傳/下載文件到遠(yuǎn)程服務(wù)器。
  • 測試自動(dòng)化:模擬客戶端發(fā)送 HTTP 請(qǐng)求驗(yàn)證接口功能。

8. 官方文檔與資源

Apache HttpClient 官方文檔Apache HttpComponents – HttpClient Overview

GitHub 倉庫https://github.com/apache/httpcomponents-client

到此這篇關(guān)于Apache HttpClient使用的文章就介紹到這了,更多相關(guān)Apache HttpClient使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Linux中使用crond工具創(chuàng)建定時(shí)任務(wù)的方法

    Linux中使用crond工具創(chuàng)建定時(shí)任務(wù)的方法

    這篇文章主要介紹了Linux中使用crond工具創(chuàng)建定時(shí)任務(wù)的方法,本文通過多種方法給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • Linux NFS服務(wù)器安裝與配置思路分析

    Linux NFS服務(wù)器安裝與配置思路分析

    NFS 是Network File System的縮寫,即網(wǎng)絡(luò)文件系統(tǒng),可以讓不同的客戶端掛載使用同一個(gè)目錄,作為共享存儲(chǔ)使用,這樣可以保證不同的節(jié)點(diǎn)客戶端數(shù)據(jù)一致性,在集群架構(gòu)中經(jīng)常用到.這篇文章主要介紹了Linux NFS服務(wù)器安裝與配置思路,需要的朋友可以參考下
    2016-10-10
  • linux開機(jī)啟動(dòng)nodemanager步驟

    linux開機(jī)啟動(dòng)nodemanager步驟

    這篇文章主要介紹了linux開機(jī)啟動(dòng)nodemanager的步驟,大家參考使用吧
    2014-01-01
  • CentOS 6.8 NFS 文件共享設(shè)置的方法

    CentOS 6.8 NFS 文件共享設(shè)置的方法

    這篇文章主要介紹了CentOS 6.8 NFS 文件共享設(shè)置的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • Linux下淺談crond與crontab的命令用法

    Linux下淺談crond與crontab的命令用法

    本篇文章主要介紹了Linux下淺談crond與crontab的用法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-06-06
  • CentOS6.4安裝Apache+MySQL+PHP圖文教程

    CentOS6.4安裝Apache+MySQL+PHP圖文教程

    這篇文章主要介紹了CentOS6.4安裝Apache+MySQL+PHP圖文教程,需要的朋友可以參考下。
    2016-10-10
  • linux系統(tǒng)下一個(gè)冷門的RAID卡ioc0及其監(jiān)控mpt-status

    linux系統(tǒng)下一個(gè)冷門的RAID卡ioc0及其監(jiān)控mpt-status

    這篇文章主要介紹了linux系統(tǒng)下一個(gè)冷門的RAID卡ioc0及其監(jiān)控mpt-status,需要的朋友可以參考下
    2016-05-05
  • Linux下gdb調(diào)試打印進(jìn)程內(nèi)存信息方式

    Linux下gdb調(diào)試打印進(jìn)程內(nèi)存信息方式

    這篇文章主要介紹了Linux下gdb調(diào)試打印進(jìn)程內(nèi)存信息方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • centos7系統(tǒng)nginx服務(wù)器下phalcon環(huán)境搭建方法詳解

    centos7系統(tǒng)nginx服務(wù)器下phalcon環(huán)境搭建方法詳解

    這篇文章主要介紹了centos7系統(tǒng)nginx服務(wù)器下phalcon環(huán)境搭建方法,結(jié)合具體實(shí)例形式詳細(xì)分析了centos7的nginx服務(wù)器搭建phalcon的具體操作步驟與相關(guān)設(shè)置技巧,需要的朋友可以參考下
    2019-09-09
  • 詳解Linux中如何釋放交換空間swap

    詳解Linux中如何釋放交換空間swap

    交換內(nèi)存swap是linux下一個(gè)虛擬內(nèi)存的概念,它是利用磁盤空間虛擬出的一塊邏輯內(nèi)存,用于解決物理內(nèi)存容量不足的問題,本文就給大家介紹一下在Linux中如何釋放交換空間swap,需要的朋友可以參考下
    2023-07-07

最新評(píng)論