Java post请求工具类

本文详细解析了如何在优快云上发布一篇高质量的技术博客,包括标题、标签和内容的优化策略,旨在帮助作者提高文章的可见性和吸引力。
### Java POST 请求工具类 示例代码 以下是一个完整的 Java POST 请求工具类实现,支持设置请求头、请求参数以及超时时间。该工具类基于 `HttpURLConnection` 实现[^3]。 ```java import java.io.OutputStream; import java.net.HttpURLConnection; import java.net.URL; import java.util.Map; public class HttpPostUtil { /** * 发送POST请求 * * @param url 请求地址 * @param headers 请求头参数 * @param parameters 请求体参数 * @return 响应结果 * @throws Exception 如果发生异常 */ public static String sendPostRequest(String url, Map<String, String> headers, Map<String, Object> parameters) throws Exception { URL obj = new URL(url); HttpURLConnection con = (HttpURLConnection) obj.openConnection(); // 设置通用属性 con.setRequestMethod("POST"); con.setDoOutput(true); // 启用输出流 con.setConnectTimeout(5000); // 设置连接超时时间(毫秒) con.setReadTimeout(5000); // 设置读取超时时间(毫秒) // 设置自定义请求头 if (headers != null && !headers.isEmpty()) { for (Map.Entry<String, String> entry : headers.entrySet()) { con.setRequestProperty(entry.getKey(), entry.getValue()); } } // 构建请求体 StringBuilder postData = new StringBuilder(); if (parameters != null && !parameters.isEmpty()) { for (Map.Entry<String, Object> entry : parameters.entrySet()) { if (postData.length() != 0) { postData.append('&'); } postData.append(entry.getKey()).append('=').append(entry.getValue().toString()); } } // 写入请求体 try (OutputStream os = con.getOutputStream()) { byte[] input = postData.toString().getBytes("utf-8"); os.write(input, 0, input.length); } // 获取响应码 int responseCode = con.getResponseCode(); if (responseCode == HttpURLConnection.HTTP_OK) { // 成功状态码 try (java.util.Scanner scanner = new java.util.Scanner(con.getInputStream(), "UTF-8")) { scanner.useDelimiter("\\A"); return scanner.hasNext() ? scanner.next() : ""; } } else { throw new Exception("POST request failed with response code: " + responseCode); } } } ``` #### 工具类使用示例 以下是如何使用上述工具类发送 POST 请求的示例代码: ```java import java.util.HashMap; import java.util.Map; public class Main { public static void main(String[] args) { try { String url = "https://example.com/api"; Map<String, String> headers = new HashMap<>(); headers.put("Content-Type", "application/x-www-form-urlencoded"); headers.put("Authorization", "Bearer your_token_here"); Map<String, Object> parameters = new HashMap<>(); parameters.put("key1", "value1"); parameters.put("key2", "value2"); String response = HttpPostUtil.sendPostRequest(url, headers, parameters); System.out.println("Response: " + response); } catch (Exception e) { e.printStackTrace(); } } } ``` #### 工具类功能说明 1. **请求头设置**:通过传入 `headers` 参数,可以灵活设置请求头,例如 `Content-Type` 和 `Authorization`。 2. **请求体构建**:支持将键值对形式的参数转换为 URL 编码格式的请求体[^3]。 3. **超时控制**:默认设置了 5 秒的连接和读取超时时间,可根据需要调整。 4. **错误处理**:当 HTTP 响应码不是 200 时,会抛出异常并返回具体的错误信息。 --- #### 注意事项 - 如果需要发送 JSON 格式的请求体,需将 `Content-Type` 设置为 `application/json`,并将参数序列化为 JSON 字符串[^3]。 - 在实际项目中,建议对工具类进行更全面的异常捕获和日志记录,以提高稳定性[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值