使用Apache HttpClient发起一个POST HTTP请求

Apache HttpClient 是一个强大的Java库,用于处理HTTP请求。

它支持多种HTTP方法,包括GET、POST、PUT、DELETE等。

本教程将重点介绍如何使用Apache HttpClient发送POST HTTP请求。

POST请求通常用于向服务器发送数据以创建或更新资源。

我们将演示如何发送带有JSON数据的POST请求,并处理响应。

Maven依赖

要使用Apache HttpClient,请在你的pom.xml文件中添加以下依赖:

xml 复制代码
<dependency>
    <groupId>org.apache.httpcomponents.client5</groupId>
    <artifactId>httpclient5</artifactId>
    <version>5.3</version>
</dependency>

示例场景

我们将创建一个简单的Java类,向指定URL发送带有JSON数据的POST请求,并打印响应。

JSONPlaceholder API

我们将使用JSONPlaceholder API作为示例。

该API提供了模拟在线RESTful端点,用于测试和原型设计。POST请求的URL为:
https://jsonplaceholder.typicode.com/posts

发送POST请求的Java类

创建名为HttpClientPostExample的类,并使用以下代码:

java 复制代码
import org.apache.hc.client5.http.classic.methods.HttpPost;
import org.apache.hc.client5.http.classic.methods.CloseableHttpResponse;
import org.apache.hc.client5.http.impl.classic.CloseableHttpClient;
import org.apache.hc.client5.http.impl.classic.HttpClients;
import org.apache.hc.core5.http.ContentType;
import org.apache.hc.core5.http.io.entity.EntityUtils;
import org.apache.hc.core5.http.io.entity.StringEntity;

public class HttpClientPostExample {

    public static void main(String[] args) {
        String url = "https://jsonplaceholder.typicode.com/posts";
        String json = "{\"title\":\"foo\",\"body\":\"bar\",\"userId\":1}";

        // 创建HttpClient实例
        try (CloseableHttpClient httpClient = HttpClients.createDefault()) {
            // 创建HttpPost请求
            HttpPost request = new HttpPost(url);

            // 设置JSON负载
            StringEntity entity = new StringEntity(json, ContentType.APPLICATION_JSON);
            request.setEntity(entity);

            // 设置请求头
            request.setHeader("Accept", "application/json");
            request.setHeader("Content-type", "application/json");

            // 执行请求
            try (CloseableHttpResponse response = httpClient.execute(request)) {
                // 获取响应状态码
                System.out.println("响应码: " + response.getCode());

                // 获取响应内容
                String content = EntityUtils.toString(response.getEntity());
                System.out.println("响应内容: \n" + content);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

说明

  • 添加Maven依赖org.apache.httpcomponents.client5:httpclient5 依赖提供了使用Apache HttpClient创建和执行HTTP请求所需的类。
  • 创建HttpClient实例CloseableHttpClient httpClient = HttpClients.createDefault(); 使用默认配置创建了一个CloseableHttpClient实例。
  • 创建HttpPost请求HttpPost request = new HttpPost(url); 为指定URL创建了一个HttpPost请求。
  • 设置JSON负载StringEntity entity = new StringEntity(json, ContentType.APPLICATION_JSON); 创建了一个包含JSON数据的StringEntity,并将内容类型设置为application/jsonrequest.setEntity(entity); 将实体(负载)设置到POST请求中。
  • 设置请求头 :通过调用setHeader方法设置了AcceptContent-type头部信息。
  • 执行请求try (CloseableHttpResponse response = httpClient.execute(request)) { ... } 执行POST请求并获取响应。
  • 获取响应状态码System.out.println("响应码: " + response.getCode()); 打印HTTP响应的状态码。
  • 获取响应内容String content = EntityUtils.toString(response.getEntity()); 将响应实体转换为字符串并打印内容。

运行示例

只需运行HttpClientPostExample类,你就能在控制台看到响应状态码和响应内容。

示例输出

复制代码
响应码: 201
响应内容: 
{
  "title": "foo",
  "body": "bar",
  "userId": 1,
  "id": 101
}

额外配置

  • 设置自定义头部 :可以通过HttpPost对象上的setHeader方法设置POST请求的自定义头部。
  • 处理重定向 :默认情况下,Apache HttpClient会自动处理重定向。你可以通过自定义HttpClientBuilder来调整这种行为。
  • 设置超时 :可以使用RequestConfig来设置连接和套接字超时。

结论

使用Apache HttpClient发送POST HTTP请求既简单又灵活。

按照本教程,你现在应该能够创建并执行POST请求、处理响应以及定制HTTP请求和响应过程中的各种方面了。

Apache HttpClient提供了一整套功能,使其成为处理Java应用程序中HTTP操作的优秀选择。

JSONPlaceholder API作为一个实用且方便的来源,可用于测试和原型化你的HTTP请求。

相关推荐
晏宁科技YaningAI43 分钟前
全球短信路由系统设计逻辑打破 80%送达率瓶颈:工程实践拆解
网络·网络协议·架构·gateway·信息与通信·paas
WIN-U62 小时前
新版华三H3C交换机配置NTP时钟步骤 示例(命令及WEB配置)
网络协议·tcp/ip·http
F1FJJ2 小时前
什么是 Shield CLI?视频讲解:一条命令,可浏览器远程访问一切内部服务(RDP/VNC/SSH/数据库等)
运维·网络·数据库·网络协议·ssh
F1FJJ3 小时前
Shield CLI 命令全解析:15 个命令覆盖所有远程访问场景
网络·数据库·网络协议·容器·开源软件
Shepherd06195 小时前
【IT 实战】Apache 反向代理 UniFi Controller 的终极指北(解决白屏、502、400 错误)
运维·网络·apache·it·unifi
额1295 小时前
CentOS 7 安装apache部署discuz导入数据库表
数据库·centos·apache
nbsaas-boot6 小时前
基于 HTTP 构建 MCP Tools 的完整工程解析
网络·网络协议·http·ai
i建模6 小时前
SSL: CERTIFICATE_VERIFY_FAILED feishu 机器人CoPaw
运维·网络·网络协议·ssl·openclaw
王码码20356 小时前
Flutter for OpenHarmony:使用 pluto_grid 打造高性能数据网格
flutter·http·华为·架构·harmonyos
先跑起来再说6 小时前
从原理到实践:彻底搞懂Cookie和Session的区别
计算机网络·http·https