HttpClient发送Post请求————StringEntity 和 UrlEncodedFormEntity 的区别

HttpClient的Post请求中,StringEntity提供灵活的参数设置,可自定义ContentType,适合发送JSON等格式数据。而UrlEncodedFormEntity默认采用application/x-www-form-urlencoded格式,适合传统表单数据。使用时注意两者对ContentType和参数类型的要求,以匹配服务器期望的数据格式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

HttpClient发送Post请求————StringEntity 和 UrlEncodedFormEntity 的区别

首先说StringEntity
StringEntity extends AbstractHttpEntity implements Cloneable
继承于AbstractHttpEntity类,这个类做参数的时候设置比较灵活,通过类的构造方法可以看到有两个参数,一个是具体的参数值(string串),另一个是ContentType,通过重写的构造方法看到,当不指定ContentType时默认的ContentType是text/plain,具体看下图构造方法:
在这里插入图片描述
默认通过一个参数构造方法创建对象,ContentType得值是 ContentType.DEFAULT_TEXT,找到来源,

DEFAULT_TEXT的值是 create(“text/plain”, Consts.ISO_8859_1)设定的
在这里插入图片描述
HttpPost post=new HttpPost(“https://api.weixin.qq.com/cgi-bin/template/api_set_industry?access_token=ACCESS_TOKEN”);
JSONObject param=new JSONObject();
param.put(“key”,“value”);
StringEntity requestentity=new StringEntity(param.toString());
requestentity.setContentType(ContentType.APPLICATION_JSON.toString());
post.setEntity(requestentity);
所以当要通过post发送json数据时就要额外设置Contentype为application/json或在初始化时传入一个Contentype类型。其他类型也一样可以自由设置,要注意的就是默认值,以免忘记设定而造成请求出错。

2.UrlEncodeFormEntity
UrlEncodeFormEntity继承字上面的StringEntity ,可以认为指定类型的entity,说到指定类型,UrlEncodeFormEntity默认指定了他的ContentType就是application/x-www-form-urlencoded,所以使用这个类做参数,会将参数以key1=value1&key2=value2的键值对形式发出。类似于传统的application/x-www-form-urlencoded表单上传。

对于ContentType指定的值:
在这里插入图片描述

从构造方法看到在初始化时就指定了ContentType,也就决定了参数的形式,还要注意到参数是以UrlEncodeFormEntity放到HttpPost对象里的,但是UrlEncodeFormEntity创建时必须是NameValuePair类型的对象或对象的集合作为他的构造参数,不能是String类型,上面的构造方法里面可以看到参数类型是Iterable<? extends NameValuePair> parameters,这是一个死的限制,也就是说要用UrlEncodeFormEntity作为参数传递,那数据格式组装就必须要用NameValuePair类型:

List<NameValuePair> params=new ArrayList<>();
	params.add(new BasicNameValuePair("key1","value1"));
	params.add(new BasicNameValuePair("key2","value2"));
	params.add(new BasicNameValuePair("key3","value3"));
	UrlEncodedFormEntity  entity=new UrlEncodedFormEntity(params,"UTF-8");
	post.setEntity(entity);

如上面示例代码,只能是这种类型构建参数

综上所述,StringEntity可以用来灵活设定参数格式形式,而UrlEncodeFormEntity则适合于传统表单格式的参数形式,至于到底用什么形式,也要看请求目标服务的数据接收形式。

例子:

    public static String send(String url, JSONObject jsonObject, String encoding) throws Exception, IOException {
        String body = "";
        //创建httpclient对象
        CloseableHttpClient client = HttpClients.createDefault();
        //创建post方式请求对象
        HttpPost httpPost = new HttpPost(url);

        //装填参数
        StringEntity s = new StringEntity(""}", "utf-8");
        s.setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE,
                "application/json"));
        //设置参数到请求对象中
        httpPost.setEntity(s);
        System.out.println("请求地址:" + url);
        if (header != null) {
            Set<Map.Entry <String, String>> entrySet = header.entrySet();
            for (Map.Entry <String, String> entry : entrySet) {
                // 设置到请求头到HttpRequestBase对象中
                httpPost.setHeader(entry.getKey(), entry.getValue());
            }
        }

        //执行请求操作,并拿到结果(同步阻塞)
        CloseableHttpResponse response = client.execute(httpPost);
        //获取结果实体
        HttpEntity entity = response.getEntity();
        if (entity != null) {
            //按指定编码转换结果实体为String类型
            body = EntityUtils.toString(entity, encoding);
        }
        EntityUtils.consume(entity);
        //释放链接
        response.close();
        return body;
    }
<think>嗯,用户想了解如何使用HttpClient发送POST请求,特别是示例代码。我需要根据提供的引用内容来整理步骤。首先,引用[1][3]提到Apache HttpClient库在Java中的应用,所以应该以Java为例。引用[2]展示了表单提交的HTML例子,但用户需要的是Java代码。引用[4]导入了UrlEncodedFormEntity,这可能用于表单数据。 第一步,应该引入依赖,比如Maven的依赖配置,这样用户知道需要哪些库。然后,创建HttpClient实例,引用[3]提到使用HttpClients.createDefault()方法。接下来是构造POST请求,使用HttpPost类,设置URL。处理参数部分,引用[2][4]提到表单数据,所以用NameValuePairUrlEncodedFormEntity来封装参数,并设置到请求中。执行请求用execute方法,获取响应后处理状态码响应体。此外,引用[1]提到JSON数据,所以还需要示例如何处理JSON请求体,用StringEntity设置ContentType为application/json。 需要注意代码的正确性,比如关闭资源,使用try-with-resources来自动管理。可能用户会遇到参数编码或头设置的问题,所以示例中要展示清楚。最后,生成相关问题,比如异常处理、文件上传等,帮助用户扩展知识。</think>### 如何使用HttpClient发送POST请求(含示例代码) 以下是使用Apache HttpClient发送POST请求的详细步骤示例代码: #### 1. 添加依赖(Maven) ```xml <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient</artifactId> <version>4.5.13</version> </dependency> ``` #### 2. 基础表单POST请求 ```java import org.apache.http.client.methods.HttpPost; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.NameValuePair; import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.message.BasicNameValuePair; public class FormPostExample { public static void main(String[] args) { try (CloseableHttpClient httpClient = HttpClients.createDefault()) { HttpPost post = new HttpPost("http://example.com/api"); // 设置表单参数 List<NameValuePair> params = new ArrayList<>(); params.add(new BasicNameValuePair("username", "test")); params.add(new BasicNameValuePair("password", "123456")); post.setEntity(new UrlEncodedFormEntity(params, "UTF-8")); // 执行请求 try (CloseableHttpResponse response = httpClient.execute(post)) { System.out.println("响应状态: " + response.getStatusLine()); // 处理响应内容... } } } } ``` > 关键点:`UrlEncodedFormEntity`用于封装表单参数[^4] #### 3. 发送JSON数据的POST请求 ```java import org.apache.http.entity.StringEntity; public class JsonPostExample { public static void main(String[] args) { try (CloseableHttpClient httpClient = HttpClients.createDefault()) { HttpPost post = new HttpPost("http://example.com/api"); String json = "{\"name\":\"John\", \"age\":30}"; // 设置JSON请求StringEntity entity = new StringEntity(json); entity.setContentType("application/json"); post.setEntity(entity); // 执行请求... } } } ``` > 注意:需要设置`Content-Type: application/json`[^1] #### 4. 带自定义头部的POST请求 ```java post.setHeader("User-Agent", "Mozilla/5.0"); post.setHeader("Authorization", "Bearer token123"); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值