HttpClient簡單介紹

来源:http://www.cnblogs.com/spring-Ganoder/archive/2017/08/29/httpclient.html
-Advertisement-
Play Games

使用 PoolingHttpClientConnectionManager 鏈接池管理類 ...


public class HttpClientUtil {

    private static PoolingHttpClientConnectionManager connectionManager = null;

    private static IdleConnectionMonitorThread scan = null;

    private static int MAX_CONN_TOTAL = 1000;
    private static int MAX_CONN_PERROUTE = 600;

    public static HttpClientResponseEntity webRequestToServer(String requestUri, String method, byte[] requestData, final int timeOut, String encodeName, Map<String, String> headers) throws Exception {

        HttpClientResponseEntity responseEntity = new HttpClientResponseEntity();
        CloseableHttpResponse response = null;
        InputStream inputStream = null;
        HttpUriRequest httpUriRequest = null;

        try {
            //設置協議http和https對應的處理socket鏈接工廠對象
            SSLContext sslContext = SSLContexts.custom().loadTrustMaterial(null, new TrustSelfSignedStrategy() {
                @Override
                public boolean isTrusted(X509Certificate[] chain, String authType) throws CertificateException {
                    return true;
                }
            }).build();

            SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(sslContext, new String[]{"SSLv2Hello", "SSLv3", "TLSv1", "TLSv1.1", "TLSv1.2"}, null, NoopHostnameVerifier.INSTANCE);
            Registry<ConnectionSocketFactory> socketFactoryRegistry = RegistryBuilder.<ConnectionSocketFactory>create()
                    .register("http", PlainConnectionSocketFactory.INSTANCE)
                    .register("https", sslsf)
                    .build();
            RequestConfig requestConfig = RequestConfig.custom()
                    .setConnectTimeout(timeOut)
                    .setSocketTimeout(timeOut)
                    .setConnectionRequestTimeout(timeOut)
                    .build();
            SocketConfig socketConfig = SocketConfig.custom()
                    .setSoTimeout(timeOut)
                    .build();
            if (connectionManager == null) {
                connectionManager = new PoolingHttpClientConnectionManager(socketFactoryRegistry);
                connectionManager.setMaxTotal(MAX_CONN_TOTAL);
                connectionManager.setDefaultMaxPerRoute(MAX_CONN_PERROUTE);
            }
            if (scan == null) {
                //清理無效的連接
                scan = new IdleConnectionMonitorThread(connectionManager);
                scan.start();
            }
            HttpClientBuilder httpClientBuilder = HttpClientBuilder.create();
            httpClientBuilder.setConnectionManager(connectionManager);
            httpClientBuilder.setDefaultRequestConfig(requestConfig);
            httpClientBuilder.setDefaultSocketConfig(socketConfig);
            httpClientBuilder.setRetryHandler(new DefaultHttpRequestRetryHandler(0, false));
            httpClientBuilder.setKeepAliveStrategy(new ConnectionKeepAliveStrategy() {
                @Override
                public long getKeepAliveDuration(HttpResponse response, HttpContext context) {
                    final HeaderElementIterator it = new BasicHeaderElementIterator(response.headerIterator(HTTP.CONN_KEEP_ALIVE));
                    while (it.hasNext()) {
                        final HeaderElement he = it.nextElement();
                        final String param = he.getName();
                        final String value = he.getValue();
                        if (value != null && param.equalsIgnoreCase("timeout")) {
                            try {
                                return Long.parseLong(value) * 1000;
                            } catch (final NumberFormatException ignore) {
                            }
                        }
                    }
                    return timeOut;
                }
            });
            CloseableHttpClient httpClient = httpClientBuilder.build();
            switch (method) {
                case "POST":
                    HttpPost httpPost = new HttpPost(requestUri);
                    httpPost.setEntity(new ByteArrayEntity(requestData));
                    if (headers != null) {
                        for (Map.Entry<String, String> entry : headers.entrySet()) {
                            httpPost.setHeader(entry.getKey(), entry.getValue());
                        }
                    }
                    httpUriRequest = httpPost;
                    break;
                case "GET":
                    HttpGet httpGet = new HttpGet(requestUri);
                    if (headers != null) {
                        for (Map.Entry<String, String> entry : headers.entrySet()) {
                            httpGet.setHeader(entry.getKey(), entry.getValue());
                        }
                    }
                    httpUriRequest = httpGet;
                    break;
                default:
                    throw new Exception("請求方式不存在!");

            }
            response = httpClient.execute(httpUriRequest);
            inputStream = response.getEntity().getContent();
            responseEntity.setResponseCode(String.valueOf(response.getStatusLine().getStatusCode()));
            if (HttpStatus.SC_OK == response.getStatusLine().getStatusCode()) {
                ByteArrayOutputStream swapStream = new ByteArrayOutputStream();
                byte[] buff = new byte[1000];
                int ri = 0;
                while ((ri = inputStream.read(buff, 0, 1000)) > 0) {
                    swapStream.write(buff, 0, ri);
                }
                responseEntity.setResponseByteArray(swapStream.toByteArray());
                responseEntity.setResponseBody(new String(responseEntity.getResponseByteArray(), encodeName));
            } else {
                responseEntity.setResponseMsg(response.getStatusLine().getReasonPhrase());
            }
            inputStream.close();
        } catch (Exception e) {
            responseEntity.setResponseCode("-1");
            responseEntity.setResponseMsg(e.getMessage());
            if (e instanceof SocketTimeoutException) {
                responseEntity.setResponseCode("timeout");
                responseEntity.setResponseMsg("介面超時(超時時間:" + timeOut + "毫秒)");
            }
        } finally {
            if (httpUriRequest != null) {
                httpUriRequest.abort();
            }
            if (response != null) {
                EntityUtils.consumeQuietly(response.getEntity());
            }
        }
        return responseEntity;
    }
}

使用 PoolingHttpClientConnectionManager 鏈接池管理類


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一:什麼是協同程式? 在主線程運行的同時開啟另一段邏輯處理,來協助當前程式的執行,協程很像多線程,但是不是多線程,Unity的協程實在每幀結束之後去檢測yield的條件是否滿足。 二:Unity3D中的碰撞器和觸發器的區別? 碰撞器是觸發器的載體,而觸發器只是碰撞器身上的一個屬性。當Is Trigg ...
  • 環境:win7 ,vs2013,sql server 2008 今天在進行性model frist實例時遇到下麵的問題 解決辦法:新建一個環境變數,如下圖所示 我將vs2013安裝在E盤的,ok,重啟vs2013問題解決 附註:1.如果表中的欄位需要更改,在第二次生成的腳步不要點執行,否則會將資料庫 ...
  • 一、準備工作 1.要想編寫一個發送郵件的小工具,首先得瞭解以下內容: 收件人:這封郵件的接收人,郵件發送者溝通交流的對象。 抄送:這封郵件的接收人,郵件發送者希望被抄送者瞭解郵件內容。 密件抄送:這封郵件的接收人,與抄送的唯一區別就是它能夠讓各個收件人無法查看到這封郵件同時還發送給了哪些人。 郵件主 ...
  • 直接用dotnet命令來運行你的程式,(dotnet的啟動真的很快)。在你的項目文件夾下加一個批處理,如:Run.cmd ...
  • 錄音工具,推薦使用Win7操作系統自帶錄音機。 修改錄音機輸出開始→所有程式→附件→右擊錄音機→屬性,在目標欄路徑有添加 空格/file outputfile.wav。 使用錄音機錄製相關音頻XXX.wav 具體代碼如下 ...
  • 在常見的ORM框架中,大都提供了使用註解方式來實現entity與資料庫的映射,這裡簡單地使用自定義註解與反射來生成可執行的sql語句。 這是整體的目錄結構,本來是為複習註解建立的項目^.^ 好的,首先我們來確定思路。 1. 自定義@Table @Column註解, 我們稍微模仿hibernate,讓 ...
  • 我們伺服器內用leveldb存一些不是很重要的, 但是又需要(半)持久化的東西. 可是自從2016到現在, 碰見好幾次不同類型的死鎖. 直到今天, 才發現真正的原因, 那就是leveldb不支持fork. 所以在你使用leveldb的時候, 一定需要註意初始化順序: fork init leveld ...
  • virtualenv virtualenv用於創建獨立的Python環境,多個Python相互獨立,互不影響,它能夠:1. 在沒有許可權的情況下安裝新套件2. 不同應用可以使用不同的套件版本3. 套件升級不影響其他應用 安裝 使用方法 如,創建**ENV**的虛擬環境 預設情況下,虛擬環境會依賴系統環 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...