SpringBoot使用httpclient发送Get,Post请求

SpringBoot版本为2.0.1,pom文件添加httpclient依赖

编写HttpUtils工具类

import org.apache.commons.lang3.StringUtils;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.utils.URIBuilder;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import javax.servlet.http.HttpServletRequest;
import java.io.*;
import java.net.URI;
import java.nio.charset.Charset;
/**
 * @author YoonaLt
 */
public class HttpUtils {
    /**
     * 发送 get 请求
     *
     * @param url 请求地址
     * @return 请求结果
     */
    public static String get(String url) {
        String result = null;
        CloseableHttpResponse response = null;
        CloseableHttpClient httpclient = HttpClients.createDefault();
        try {
            // 创建uri
            URIBuilder builder = new URIBuilder(url);
            URI uri = builder.build();
            // 创建http GET请求
            HttpGet httpGet = new HttpGet(uri);
            // 执行请求
            response = httpclient.execute(httpGet);
            if (response.getStatusLine().getStatusCode() == 200) {
                result = EntityUtils.toString(response.getEntity(), "UTF-8");
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return result;
    }
    /**
     * 发送 post 请求
     *
     * @param url     请求地址
     * @param jsonStr Form表单json字符串
     * @return 请求结果
     */
    public static String post(String url, String jsonStr) {
        // 创建httpClient
        CloseableHttpClient httpClient = HttpClients.createDefault();
        // 创建post请求方式实例
        HttpPost httpPost = new HttpPost(url);
        // 设置请求头 发送的是json数据格式
        httpPost.setHeader("Content-type", "application/json;charset=utf-8");
        httpPost.setHeader("Connection", "Close");
        // 设置参数---设置消息实体 也就是携带的数据
        StringEntity entity = new StringEntity(jsonStr, Charset.forName("UTF-8"));
        // 设置编码格式
        entity.setContentEncoding("UTF-8");
        // 发送Json格式的数据请求
        entity.setContentType("application/json");
        // 把请求消息实体塞进去
        httpPost.setEntity(entity);
        // 执行http的post请求
        CloseableHttpResponse httpResponse;
        String result = null;
        try {
            httpResponse = httpClient.execute(httpPost);
            result = EntityUtils.toString(httpResponse.getEntity(), "UTF-8");
        } catch (IOException e) {
            e.printStackTrace();
        }
        return result;
    }
    /**
     * 获取请求ip地址
     */
    public static String getRequestIp(HttpServletRequest request) {
        String ip = request.getHeader("X-Forwarded-For");
        if (StringUtils.isNotEmpty(ip) && !"unKnown".equalsIgnoreCase(ip)) {
            //多次反向代理后会有多个ip值,第一个ip才是真实ip
            int index = ip.indexOf(",");
            if (index != -1) {
                return ip.substring(0, index);
            } else {
                return ip;
            }
        }
        ip = request.getHeader("X-Real-IP");
        if (StringUtils.isNotEmpty(ip) && !"unKnown".equalsIgnoreCase(ip)) {
            return ip;
        }
        return request.getRemoteAddr();
    }
}
<think>好的,我现在需要帮助用户了解如何在Spring Boot中使用Apache HttpClient发送GETPOST请求。首先,我得确认用户的基础知识,他们可能已经知道Spring Boot的基本概念,但对HttpClient的具体使用不太清楚。 首先,我需要介绍Apache HttpClient的基本概念,说明它是一个强大的HTTP客户端库,适合在Spring Boot项目中使用。然后,分步骤讲解如何添加依赖,因为这是第一步,用户需要配置Maven或Gradle。这里要注意版本选择,特别是HttpClient 4.5之后的版本可能有变化,需要给出最新的稳定版本示例。 接下来,创建HttpClient实例。用户可能对连接池和配置参数不太熟悉,需要简单解释每个配置的作用,比如连接超时和请求超时的区别,SSL上下文的作用,但保持简洁,避免信息过载。 然后,处理GET请求。需要展示如何构建URI,添加请求头,执行请求并处理响应。这里要注意异常处理,比如IOException,可能需要在代码示例中加入try-catch块,或者建议用户在实际使用时处理异常。同时,要提到不同响应类型的处理方式,比如字符串、字节数组或流,让用户知道如何根据需求调整。 对于POST请求,同样需要分步骤说明。构建URI,创建StringEntity,并设置内容类型,比如application/json。这里可能需要解释为什么需要设置ContentType,以及不同内容类型的影响。示例中使用JSON,这是常见情况,但也可以提及其他类型,比如表单数据。 在POST示例中,展示如何执行请求并处理响应,强调检查状态码的重要性,比如201表示创建成功。同时,提醒用户处理可能的异常情况,确保资源释放,比如关闭响应和HttpClient实例。 最后,对比GETPOST的不同应用场景,帮助用户理解何时使用哪种方法。补充说明部分需要涵盖异常处理、连接池管理和日志记录,这些都是实际开发中需要注意的点。可能用户在实际使用时会遇到超时或连接问题,提供配置建议和日志查看方法能帮助他们调试。 整个过程中,要保持代码示例的简洁和可复制性,确保用户能够直接运行示例。同时,语言要口语化,避免过于技术性的术语,让初学者也能理解。可能用户的实际项目需求不同,比如是否需要异步请求或更复杂的配置,但当前问题集中在基础的GETPOST,所以先覆盖这些,后续如果有更深入的问题再展开。 检查是否有遗漏的步骤,比如依赖管理是否正确,是否需要排除冲突的库,或者是否需要配置Spring Boot的自动配置。另外,确保示例中的URL和路径是用户可替换的,避免使用真实API,防止用户直接复制时出错。 总结来说,需要结构清晰,分步骤讲解,每个部分都有代码示例和解释,帮助用户从零开始实现HttpClientGETPOST请求,并在Spring Boot中集成使用。</think>以下是 Spring Boot 中集成 Apache HttpClient 发送 GET/POST 请求的完整指南: --- ### **一、环境准备** #### 1. 添加 Maven 依赖 ```xml <!-- Apache HttpClient --> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient</artifactId> <version>4.5.13</version> <!-- 使用最新稳定版本 --> </dependency> ``` #### 2. 创建 HttpClient 实例(推荐使用连接池) ```java @Configuration public class HttpClientConfig { @Bean public CloseableHttpClient httpClient() { return HttpClients.custom() .setConnectionTimeToLive(30, TimeUnit.SECONDS) // 连接存活时间 .setMaxConnTotal(100) // 最大连接数 .setMaxConnPerRoute(20) // 每个路由最大连接数 .setDefaultRequestConfig(RequestConfig.custom() .setConnectTimeout(5000) // 连接超时(ms) .setSocketTimeout(10000) // 数据传输超时(ms) .build()) .setSSLContext(SSLContexts.createSystemDefault()) // SSL配置 .build(); } } ``` --- ### **二、GET 请求实战** #### 1. 基础 GET 请求 ```java @Autowired private CloseableHttpClient httpClient; public String simpleGet(String url) throws IOException { HttpGet httpGet = new HttpGet(url); // 添加请求头 httpGet.addHeader("User-Agent", "Mozilla/5.0"); httpGet.addHeader("Accept", "application/json"); try (CloseableHttpResponse response = httpClient.execute(httpGet)) { int statusCode = response.getStatusLine().getStatusCode(); if (statusCode == 200) { return EntityUtils.toString(response.getEntity(), "UTF-8"); } else { throw new RuntimeException("请求失败,状态码: " + statusCode); } } } ``` #### 2. 带参数的 GET 请求 ```java public String getWithParams(String baseUrl, Map<String, String> params) throws URISyntaxException, IOException { URIBuilder uriBuilder = new URIBuilder(baseUrl); params.forEach(uriBuilder::addParameter); HttpGet httpGet = new HttpGet(uriBuilder.build()); // ... 后续处理同上 } ``` --- ### **三、POST 请求实战** #### 1. JSON 格式 POST ```java public String postJson(String url, Object data) throws IOException { HttpPost httpPost = new HttpPost(url); // 设置JSON请求体 String json = new ObjectMapper().writeValueAsString(data); StringEntity entity = new StringEntity(json, StandardCharsets.UTF_8); entity.setContentType("application/json"); httpPost.setEntity(entity); // 添加认证头 httpPost.addHeader("Authorization", "Bearer your_token"); try (CloseableHttpResponse response = httpClient.execute(httpPost)) { if (response.getStatusLine().getStatusCode() == 201) { // 201 Created return EntityUtils.toString(response.getEntity()); } // ... 错误处理 } } ``` #### 2. 表单提交 POST ```java public String postForm(String url, Map<String, String> formData) throws IOException { HttpPost httpPost = new HttpPost(url); List<NameValuePair> params = new ArrayList<>(); formData.forEach((k, v) -> params.add(new BasicNameValuePair(k, v))); httpPost.setEntity(new UrlEncodedFormEntity(params, StandardCharsets.UTF_8)); httpPost.addHeader("Content-Type", "application/x-www-form-urlencoded"); // ... 执行请求 } ``` --- ### **四、GET vs POST 核心区别** | **特性** | GET 请求 | POST 请求 | |-------------------|----------------------------------|----------------------------------| | 数据位置 | URL 查询参数 | 请求体 | | 数据大小限制 | 受 URL 长度限制(通常 2KB-8KB) | 无明确限制 | | 安全性 | 参数明文可见 | 数据在请求体中更安全 | | 缓存 | 可被缓存 | 默认不缓存 | | 幂等性 | 幂等(多次执行结果相同) | 非幂等 | | 典型应用场景 | 获取数据、搜索、筛选 | 创建资源、提交表单、敏感操作 | --- ### **五、最佳实践建议** 1. **连接管理** - 使用连接池提升性能 - 确保每次请求后关闭响应对象 ```java try (CloseableHttpResponse response = httpClient.execute(request)) { // 处理响应 } // 自动关闭资源 ``` 2. **异常处理** ```java try { // 执行请求 } catch (ConnectTimeoutException e) { log.error("连接超时: {}", e.getMessage()); } catch (SocketTimeoutException e) { log.error("读取超时: {}", e.getMessage()); } catch (IOException e) { log.error("IO异常: {}", e.getMessage()); } finally { request.releaseConnection(); // 确保释放连接 } ``` 3. **性能调优** - 调整连接池参数(根据服务器承载能力) - 启用压缩减少传输量 ```java httpPost.addHeader("Accept-Encoding", "gzip, deflate"); ``` 4. **日志调试** 在 `application.properties` 中启用详细日志: ```properties logging.level.org.apache.http=DEBUG logging.level.org.apache.http.wire=DEBUG ``` --- 通过这种配置,您可以在 Spring Boot 应用中高效地使用 Apache HttpClient 完成各种 HTTP 交互需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值