Apache HttpComponents HttpClient

Apache HttpComponents HttpClient

Apache HttpComponents HttpClient 是 Apache 提供的一个开源库,用于在 Java 应用程序中执行 HTTP 请求和响应处理。它支持同步和异步模式,提供了对常见 HTTP 操作的简单而强大的封装。

1.HTTP 请求

实体

实体可以理解为 HTTP 请求或响应的"数据负载"。它可以包含:

  • 字符串数据(如 JSON、XML)
  • 文件数据(如图片、PDF)
  • 表单数据 (如 x-www-form-urlencodedmultipart/form-data

通过 Entity 类封装的请求体或响应体可以承载任何格式的数据,传递给服务器或从服务器接收。

请求数据格式:

  • application/x-www-form-urlencoded

    • 格式 :键值对形式,key=value,多个键值对之间用 & 连接。

    • 编码 :特殊字符和空格使用 URL 编码(如空格为 +& 编码为 %26)。

    • 应用:传统 Web 表单提交的默认格式,常用于简单数据的传输。

    • 示例

      复制代码
      name=John+Doe&age=25&city=New+York
  • application/json

    • 格式 :JSON 格式,表示复杂的对象结构,用 {} 表示对象,键值对用 : 连接。
    • 编码:不需要 URL 编码,数据直接作为 JSON 字符串传输。
    • 应用:现代 RESTful API 常用的数据格式,适合复杂对象和嵌套结构。
    复制代码
      {
        "name": "John Doe",
        "age": 25,
        "city": "New York"
      }

超时配置:

  • 连接超时 (setConnectTimeout):设定客户端与服务器建立连接的最大等待时间。

  • 请求超时 (setConnectionRequestTimeout):从连接池获取连接的最大等待时间。

  • 读取超时 (setSocketTimeout):等待服务器返回数据的最大时间。

    private static RequestConfig builderRequestConfig() {
    return RequestConfig.custom()
    .setConnectTimeout(TIMEOUT_MSEC) // 连接超时
    .setConnectionRequestTimeout(TIMEOUT_MSEC) // 请求超时
    .setSocketTimeout(TIMEOUT_MSEC) // 读取超时
    .build(); // 构建配置
    }

2. 主要功能

  • HTTP 请求的发送:支持 GET、POST、PUT、DELETE 等各种 HTTP 请求方法。
  • 连接管理:包括持久连接、连接池和请求重试等机制,确保高效和可靠的 HTTP 连接管理。
  • 超时控制:支持连接超时、请求超时、套接字超时的配置。
  • SSL 支持:内置对 HTTPS(SSL/TLS)的支持,能够通过证书进行安全通信。
  • 重定向与代理支持:自动处理 HTTP 重定向以及通过代理服务器发送请求。

3.示例网络请求

复制代码
import org.apache.http.client.methods.*;
import org.apache.http.impl.client.*;
import org.apache.http.util.EntityUtils;
import org.apache.http.entity.StringEntity;

public class HttpClientExample {
    public static void main(String[] args) throws Exception {
        // 创建HttpClient
        try (CloseableHttpClient httpClient = HttpClients.createDefault()) {
            
            // GET请求
            HttpGet getRequest = new HttpGet("http://www.example.com");
            try (CloseableHttpResponse response = httpClient.execute(getRequest)) {
                String getResult = EntityUtils.toString(response.getEntity());
                System.out.println("GET响应: " + getResult);
            }

            // POST请求
            HttpPost postRequest = new HttpPost("http://www.example.com/post");
            postRequest.setEntity(new StringEntity("{\"key\":\"value\"}", "UTF-8"));
            postRequest.setHeader("Content-Type", "application/json");
            try (CloseableHttpResponse response = httpClient.execute(postRequest)) {
                String postResult = EntityUtils.toString(response.getEntity());
                System.out.println("POST响应: " + postResult);
            }
        }
    }
}
  • GET 请求

    • 需要将返回的实体通过 EntityUtils.toString() 转为字符串,以方便处理响应内容。
  • POST 请求

    • 使用 setHeader() 设置请求头信息,例如 Content-Typeapplication/json,并指定编码方式。
    • 需要使用 StringEntity 封装请求数据为一个实体对象,方便发送带有请求体的数据。
相关推荐
7***u2166 小时前
显卡(Graphics Processing Unit,GPU)架构详细解读
大数据·网络·架构
河北瑾航科技9 小时前
广西水资源遥测终端 广西水利遥测终端 广西用水监测遥测终端 河北瑾航科技遥测终端机HBJH-B01说明书
网络·科技·水文遥测终端机·遥测终端机·广西水资源遥测终端机·广西水利遥测终端·广西用水终端
羑悻的小杀马特10 小时前
轻量跨云·掌控无界:Portainer CE + cpolar 让远程容器运维像点外卖一样简单——免复杂配置,安全直达对应集群
运维·网络·安全·docker·cpolar
愚戏师10 小时前
Python3 Socket 网络编程复习笔记
网络·笔记
降临-max11 小时前
JavaSE---网络编程
java·开发语言·网络·笔记·学习
赖small强11 小时前
【Linux 网络基础】libwebsockets HTTPS 服务端实现机制详解
linux·网络·https·tls·libwebsockets
大白的编程日记.12 小时前
【计算网络学习笔记】MySql的多版本控制MVCC和Read View
网络·笔记·学习·mysql
布朗克16813 小时前
HTTP 与 HTTPS 的工作原理及其区别
http·https
shmexon13 小时前
上海兆越亮相无锡新能源盛会,以硬核通信科技赋能“能碳未来”
网络·人工智能
Lay_鑫辰14 小时前
西门子诊断-状态和错误位(“轴”工艺对象 V1...3)
服务器·网络·单片机·嵌入式硬件·自动化