http方法调用接口

调用post方法

java 复制代码
public static String doPostWeChat(String accessToken, String url, String tradeCode) throws Exception {
    // 创建一个默认的 HTTP 客户端实例
    CloseableHttpClient client = HttpClients.createDefault();
    CloseableHttpResponse response = null; // 响应对象初始化为空

    String context = StringUtils.EMPTY; // 初始化返回内容为空字符串
    HttpPost method = new HttpPost(url); // 创建 HTTP POST 请求对象,指定请求的 URL
    try {
        // 配置请求超时时间
        RequestConfig requestConfig = RequestConfig.custom()
                .setSocketTimeout(20000) // 读取数据超时时间(20秒)
                .setConnectTimeout(40000) // 连接超时时间(40秒)
                .setConnectionRequestTimeout(20000) // 从连接池获取连接的超时时间(20秒)
                .build();
        method.setConfig(requestConfig); // 将配置应用到请求对象
        method.addHeader("Authorization", accessToken); // 添加授权头部
        method.addHeader("company", tradeCode); // 添加公司代码头部
        
        log.info(String.format("%s-----%s", "", "accessToken="+accessToken + "准备数据请求")); // 记录日志,表明请求准备发送
        response = client.execute(method); // 发送请求并获取响应
        log.info(String.format("%s-----%s", "", "accessToken="+accessToken + "请求已发送")); // 记录日志,表明请求已发送
        
        HttpEntity resEntity = response.getEntity(); // 获取响应实体
        context = EntityUtils.toString(resEntity, "UTF-8"); // 将响应实体转换为字符串(UTF-8 编码)
    } catch (Exception e) {
        throw e; // 抛出异常,供调用者处理
    } finally {
        if (response != null) {
            try {
                EntityUtils.consume(response.getEntity()); // 确保响应实体被完全消费
                response.close(); // 关闭响应对象
                method.abort(); // 中止请求
                client.close(); // 关闭 HTTP 客户端
            } catch (IOException e) {
                // 在此可以添加日志记录或其他处理逻辑
            }
        }
    }
    return context; // 返回响应内容
}

调用get接口

java 复制代码
import org.apache.http.client.methods.CloseableHttpResponse;  
import org.apache.http.client.methods.HttpGet;  
import org.apache.http.impl.client.CloseableHttpClient;  
import org.apache.http.impl.client.HttpClients;  
import org.apache.http.util.EntityUtils;  
import org.apache.commons.lang3.StringUtils;  
  
import java.io.IOException;  
  
public static String doGetWeChat(String accessToken, String url, String tradeCode) throws IOException {  
    // 创建一个默认的 HTTP 客户端实例  
    try (CloseableHttpClient client = HttpClients.createDefault()) {  
        // 创建 HTTP GET 请求对象,并添加查询参数(如果需要的话)  
        // 注意:这里假设url已经包含了所有必要的查询参数,或者我们将通过StringBuilder来动态构建它  
        // 如果需要添加查询参数,可以使用URIBuilder  
        HttpGet method = new HttpGet(url + "?accessToken=" + accessToken + "&tradeCode=" + tradeCode);  
  
        // 配置请求超时时间(可选,根据需要设置)  
        // 如果不需要,可以省略这一步  
        // ...(与POST请求中相同的配置方式)  
  
        // 发送请求并获取响应  
        try (CloseableHttpResponse response = client.execute(method)) {  
            // 获取响应实体  
            String context = EntityUtils.toString(response.getEntity(), "UTF-8"); // 将响应实体转换为字符串(UTF-8 编码)  
  
            // 可以在这里添加对响应状态码的检查  
            // 例如:if (response.getStatusLine().getStatusCode() == 200) { ... }  
  
            return context; // 返回响应内容  
        }  
    } catch (IOException e) {  
        // 处理可能的异常,比如网络问题、解析问题等  
        throw e; // 或者根据需要处理异常,比如记录日志、返回错误信息等  
    }  
}  
  
// 注意:  
// 1. 这里使用了try-with-resources语句来自动关闭CloseableHttpClient和CloseableHttpResponse,以确保资源被正确释放。  
// 2. 如果URL中包含敏感信息(如accessToken),请确保使用HTTPS来保护通信安全。  
// 3. 如果URL中的查询参数较多或构建逻辑较复杂,建议使用URIBuilder来构建URL,以避免URL编码等问题。
相关推荐
卡尔特斯4 小时前
Android Kotlin 项目代理配置【详细步骤(可选)】
android·java·kotlin
白鲸开源4 小时前
Ubuntu 22 下 DolphinScheduler 3.x 伪集群部署实录
java·ubuntu·开源
ytadpole4 小时前
Java 25 新特性 更简洁、更高效、更现代
java·后端
纪莫4 小时前
A公司一面:类加载的过程是怎么样的? 双亲委派的优点和缺点? 产生fullGC的情况有哪些? spring的动态代理有哪些?区别是什么? 如何排查CPU使用率过高?
java·java面试⑧股
JavaGuide5 小时前
JDK 25(长期支持版) 发布,新特性解读!
java·后端
用户3721574261355 小时前
Java 轻松批量替换 Word 文档文字内容
java
白鲸开源5 小时前
教你数分钟内创建并运行一个 DolphinScheduler Workflow!
java
Java中文社群6 小时前
有点意思!Java8后最有用新特性排行榜!
java·后端·面试
代码匠心6 小时前
从零开始学Flink:数据源
java·大数据·后端·flink
间彧6 小时前
Spring Boot项目中如何自定义线程池
java