我是如何实现HttpGet请求传body参数的?

点击关注公众号,利用碎片时间学习

前言

最近调用公司项目一个接口时,发现该接口是一个Get请求,入参在Body 中(json格式)。

场景如下:A服务需发送http请求调用B服务的接口(该接口为Get方式,入参是一个json字符串在body中传递)

当我看到这个接口的时候,感觉好奇怪(MMP,干嘛不用POST请求。Get就get,请求还放Body中,心里有些不爽)尽管心里不爽,但是也只能默默接受,撸起袖子 “干” 就完了!

实现过程

首先官方不推荐这样做,但是http(基于tcp的超文本传输协议)并没有规定,Get 请求不能加body

一、首先我写了一个Get请求接口,本地测试一下,便于大家直观的理解
e36efec56b20393c948b99ad83e90723.png

调用成功:

757383f0afbe80e55dec4fd6e8011e1b.png

本地使用postman调用是成功的,接下来我们使用Java代码请求调用

二.使用Http工具类调用Get请求(json参数)
  1. 引入httpclient 依赖

<!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpclient -->
 <dependency>
     <groupId>org.apache.httpcomponents</groupId>
     <artifactId>httpclient</artifactId>
     <version>4.5.6</version>
 </dependency>
  1. 定义一个HttpGet实体类

import org.apache.http.client.methods.HttpEntityEnclosingRequestBase;
import java.net.URI;
/**
 * @author xf
 * @version 1.0.0
 * @ClassName HttpGetWithEntity
 * @Description TODO 定义一个带body的GET请求 继承 HttpEntityEnclosingRequestBase
 */
public class HttpGetWithEntity extends HttpEntityEnclosingRequestBase {
    private final static String METHOD_NAME = "GET";

    @Override
    public String getMethod() {
        return METHOD_NAME;
    }
    public HttpGetWithEntity() {
        super();
    }
    public HttpGetWithEntity(final URI uri) {
        super();
        setURI(uri);
    }
    HttpGetWithEntity(final String uri) {
        super();
        setURI(URI.create(uri));
    }

}
  1. HttpGet请求公共方法

/**
     * 发送get请求,参数为json
     * @param url
     * @param param
     * @param encoding
     * @return
     * @throws Exception
     */
    public static String sendJsonByGetReq(String url, String param, String encoding) throws Exception {
        String body = "";
        //创建httpclient对象
        CloseableHttpClient client = HttpClients.createDefault();
        HttpGetWithEntity httpGetWithEntity = new HttpGetWithEntity(url);
        HttpEntity httpEntity = new StringEntity(param, ContentType.APPLICATION_JSON);
        httpGetWithEntity.setEntity(httpEntity);
        //执行请求操作,并拿到结果(同步阻塞)
        CloseableHttpResponse response = client.execute(httpGetWithEntity);
        //获取结果实体
        HttpEntity entity = response.getEntity();
        if (entity != null) {
            //按指定编码转换结果实体为String类型
            body = EntityUtils.toString(entity, encoding);
        }
        //释放链接
        response.close();
        return body;
    }
  1. 运行服务,本地测试调用一下该接口

/**
     * 测试 Get 请求
     */
    @Test
    public void test(){
        String url = "http://127.0.0.1:8012/export/getByBodyJson";
        Map<String, Object> map = new HashMap<>();
        map.put("stuName","张一山");
        map.put("school","北京戏剧学院");
        String reqParams = JSONArray.toJSON(map).toString();
        try {
            String s = sendJsonByGetReq(url, reqParams, "UTF-8");
            System.out.println("请求Get请求返回结果:"+s);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
三.使用HttpGet请求发送body入参调用成功
7ceb8d40f930973f434531142dbebb81.png

尽管这样解决了get 加body 体传参,但是仍建议大家使用post 加body!

来源:admins.blog.csdn.net/article/details/109809386

推荐:

最全的java面试题库

a8a7f643c3833e4fecb1308b11b999f3.png

PS:因为公众号平台更改了推送规则,如果不想错过内容,记得读完点一下“在看”,加个“星标”,这样每次新文章推送才会第一时间出现在你的订阅列表里。点“在看”支持我们吧!

### 如何在HTTP POST请求递文件参数 当涉及到通过HTTP POST请求发送文件时,通常会使用`multipart/form-data`编码类型来构建请求体。这种类型的表单数据允许客户端向服务器输二进制文件以及文本字段。 #### 使用HTML和JavaScript实现文件上 为了创建一个能够提交文件给服务器的应用程序,在前端部分可以通过设置HTML `<form>`标签的属性为`enctype="multipart/form-data"`并指定方法为POST来进行操作[^2]: ```html <form id="fileUploadForm" action="/upload" method="post" enctype="multipart/form-data"> <input type="file" name="myFile"/> <button type="submit">Submit</button> </form> <script> document.getElementById('fileUploadForm').addEventListener('submit', function(event){ event.preventDefault(); const formData = new FormData(this); fetch('/upload',{ method:'POST', body:formData, }) .then(response => response.json()) .then(data => { console.log('Success:', data); }) .catch((error) => { console.error('Error:', error); }); }); </script> ``` 上述代码片段展示了如何利用HTML表单配合JavaScript Fetch API发起带有文件参数的POST请求。这里的关键在于使用了`FormData`对象收集来自表单的数据,并将其作为请求主体的一部分发送出去。 #### 后端接收文件 对于后端而言,如果采用的是Node.js环境下的Express框架,则可以借助于像`multer`这样的中间件来处理多部件形式的数据流,从而轻松解析上过来的文件[^3]: ```javascript const express = require('express'); const multer = require('multer') const upload = multer({ dest: 'uploads/' }) let app = express() app.post('/upload', upload.single('myFile'), (req, res, next) => { // req.file 是 `myFile` 文件的信息 // req.body 将包含文本域的数据,如果有 }) ``` 这段脚本配置了一个简单的路由处理器用于接受文件上请求,并指定了目标存储路径。一旦接收到文件,它会被保存至本地磁盘上的特定目录内等待进一步处理。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值