相关文章推荐
暴躁的石榴  ·  翻译 - Dolibarr ERP CRM ...·  1 周前    · 
不羁的饺子  ·  Debezium | Apache Flink·  1 周前    · 
讲道义的烈酒  ·  Debezium-JSON--流式计算 ...·  1 周前    · 
从容的大脸猫  ·  零代码第三方数据接入 | TDengine ...·  1 周前    · 
迷茫的马克杯  ·  从VBA中的范围中删除特殊字符开发者社区·  1 周前    · 
狂野的圣诞树  ·  Excel ...·  2 年前    · 
酒量大的小蝌蚪  ·  使用JS实现图(1)——概述 - 知乎·  2 年前    · 
Code  ›  POST、GET、@RequestBody和@RequestParam区别[通俗易懂]开发者社区
form post请求 string
https://cloud.tencent.com/developer/article/2070401
英俊的水桶
2 周前
全栈程序员站长

POST、GET、@RequestBody和@RequestParam区别[通俗易懂]

腾讯云
开发者社区
文档 建议反馈 控制台
首页
学习
活动
专区
圈层
工具
MCP广场
文章/答案/技术大牛
发布
全栈程序员站长
社区首页 > 专栏 > POST、GET、@RequestBody和@RequestParam区别[通俗易懂]

POST、GET、@RequestBody和@RequestParam区别[通俗易懂]

作者头像
全栈程序员站长
发布 于 2022-08-11 13:36:44
发布 于 2022-08-11 13:36:44
6.3K 0
举报
文章被收录于专栏: 全栈程序员必看 全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

@RequestParam

注解@RequestParam接收的参数是来自HTTP请求体或请求url的QueryString中。

RequestParam可以接受简单类型的属性,也可以接受对象类型。

@RequestParam有三个配置参数:

  • required 表示是否必须,默认为 true ,必须。
  • defaultValue 可设置请求参数的默认值。
  • value 为接收url的参数名(相当于key值)。

@RequestParam用来处理 Content-Type 为 application/x-www-form-urlencoded 编码的内容, Content-Type 默认为该属性。@RequestParam也可用于其它类型的请求,例如:POST、DELETE等请求 。

所以在postman中,要选择body的类型为 x-www-form-urlencoded ,这样在headers中就自动变为了 Content-Type : application/x-www-form-urlencoded 编码格式。如下图所示:

但是这样不支持批量插入数据啊,如果改用 json 字符串来传值的话,类型设置为 application/json ,点击发送的话,会报错,后台接收不到值,为 null 。

但可以入参后再转换,参考如下:

代码语言: javascript
复制
   @PostMapping("/ali-receive")
    public void aliReceive(@RequestParam("message") String message) {
                ReceiveLog receiveLog = JSON.parseObject(message, ReceiveLog.class);
    }

解决Spring/SpringBoot @RequestParam注解无法读取application/json格式数据: https://blog.csdn.net/weixin_42536015/article/details/106906055

@RequestParam 接受JSON的字符串: https://blog.csdn.net/qq_40470612/article/details/104225419

不推荐使用@RequestParam接收application/json,这时候就需要使用到@RequestBody。

@RequestBody

注解@RequestBody接收的参数是 来自requestBody 中,即 请求体 。一般用于处理非 Content-Type: application/x-www-form-urlencoded 编码格式的数据,比如: application/json 、 application/xml 等类型的数据。

就 application/json 类型的数据而言,使用注解@RequestBody可以将body里面所有的json数据传到后端,后端再进行解析。

GET请求中,因为没有HttpEntity,所以@RequestBody并不适用。

POST请求中,通过HttpEntity传递的参数,必须要在请求头中声明数据的类型Content-Type,SpringMVC通过使用

HandlerAdapter 配置的HttpMessageConverters来解析HttpEntity中的数据,然后绑定到相应的bean上。

向表中批量插入数据

举个批量插入数据的例子,Controller层的写法如下图所示:

由于@RequestBody可用来处理 Content-Type 为 application/json 编码的内容,所以在postman中,选择body的类型为 row -> JSON(application/json) ,这样在 Headers 中也会自动变为 Content-Type : application/json 编码格式。body内的数据如下图所示:

批量向表中插入两条数据,这里的 saveBatchNovel() 方法已经封装了 JPA 的 saveAll() 方法。 body 里面的 json 语句的 key 值要与后端实体类的属性一一对应。

注意: 前端使用$.ajax的话,一定要指定 contentType: "application/json;charset=utf-8;" ,默认为 application/x-www-form-urlencoded 。

后端解析json数据

上述示例是传递到实体类中的具体写法,那么如果传递到非实体类中,body里面的json数据需要怎么解析呢?我们再来看下面这个例子:

在body中,我们还是输入上面的json数据,根据分析,上面的json数据是一个List数组内嵌套着map对象,那么在后台的接收形式可写为 List<Map<String, String>> ,具体代码如下图所示:

postman请求:

控制台输出:

得出结论,通过@RequestBody可以解析Body中json格式的数据。

POST请求时

@RequestBody –> JSON字符串部分

@RequestParam –> 请求参数部分

application/json格局图

form-data、x-www-form-urlencoded格局图

1、从content-type方面总结:

① form-data、x-www-form-urlencoded:不可以用@RequestBody;可以用@RequestParam。见postman的格局,这两种方式的时候没有json字符串部分。

② application/json:json字符串部分可以用@RequestBody;url中的?后面参数可以用@RequestParam。见postman的格局

2、从两种注解方式总结:

@RequestBody

代码语言: javascript
复制
(@RequestBody Map map)
(@RequestBody Object object)
application/json时候可用
form-data、x-www-form-urlencoded时候不可用

@RequestParam

代码语言: javascript
复制
(@RequestParam Map map)
application/json时候,json字符串部分不可用,url中的?后面添加参数即可用,form-data、x-www-form-urlencoded时候可用,但是要将Headers里的Content-Type删掉
代码语言: javascript
复制
(@RequestParam String waterEleId,@RequestParam String enterpriseName)
application/json时候,json字符串部分不可用,url中的?后面添加参数即可用
form-data、x-www-form-urlencoded时候可用,且参数可以没有顺序(即前端传过来的参数或者url中的参数顺序不必和后台接口中的参数顺序一致,只要字段名相同就可以),但是要将Headers里的Content-Type删掉
代码语言: javascript
复制
(@RequestParam Object object)
不管application/json、form-data、x-www-form-urlencoded都不可用

既不是@RequestBody也不是@RequestParam,没有指定参数哪种接收方式

代码语言: javascript
复制
(Map map)
(Object object)
application/json时候:json字符串部分不可用,url中的?后面添加参数不可用。
因为没有指定,它也不知道到底是用json字符串部分还是?后面添加参数部分,所以干脆都不可以用
form-data、x-www-form-urlencoded时都不可用,见图二
(HttpServletRequest request)
application/json不可用
form-data、x-www-form-urlencoded时可用

GET请求

@RequestBody

代码语言: javascript
复制
RequestBody -- Map / Object
GET请求中不可以使用@RequestBody

@RequestParam

代码语言: javascript
复制
(@RequestParam Map map)
在url中的?后面添加参数即可使用
代码语言: javascript
复制
(@RequestParam String waterEleId,@RequestParam String enterpriseName)
在url中的?后面添加参数即可使用
代码语言: javascript
复制
(@RequestParam Object object)
GET请求中不可以使用

当使用GET请求时,通过postman添加?后面的参数,不用在url中自己一个一个拼,点击Params,在下面key-value中输入就自动拼接到url中

举栗子

上传文件,包含了图中圈出来的两部分

如果这样,没有@RequestParam,那么url?后的参数就拿不到

代码语言: javascript
复制
@RequestMapping(value = "/leadingIn", method = RequestMethod.POST)
    public ResponseObj<Boolean> leadingIn(Map formData,
                                          HttpServletRequest request,
                                          Map<String, InputStream> files) {
}

如果control中这样接收,本来想formData只接收url?后的参数,结果将{ “retCode”: null, “data”: true }这部分内容也拿到了,真实意外之喜。字符串这部分内容还可以从request中取到,见下面完整方法。

代码语言: javascript
复制
@RequestMapping(value = "/leadingIn", method = RequestMethod.POST)
    public ResponseObj<Boolean> leadingIn(@RequestParam Map formData,
                                          HttpServletRequest request,
                                          Map<String, InputStream> files) {
}

完整方法

代码语言: javascript
复制
    /**
    @RequestMapping(value = "/leadingIn", method = RequestMethod.POST)
    public ResponseObj<Boolean> leadingIn(@RequestParam Map formData,
                                          HttpServletRequest request,
                                          Map<String, InputStream> files) {
        try {
            MultipartHttpServletRequest mulRequest = (MultipartHttpServletRequest) request;
            Set<Map.Entry<String, MultipartFile>> set = mulRequest.getFileMap().entrySet();
            Map<String, InputStream> listFile = new LinkedHashMap<>();
            System.out.println("个数" + set.size());
            for (Map.Entry<String, MultipartFile> each : set) {
                String fileName = each.getKey();
                MultipartFile file = each.getValue();
                //这里需要上传FTP
                try {
                    listFile.put(fileName, file.getInputStream());
                } catch (Exception ex) {
                    return new ResponseObj<>(false, null);
            String formjson = mulRequest.getParameter("content");
            ObjectMapper mapper = new ObjectMapper();
            mapper.setVisibility(PropertyAccessor.FIELD, JsonAutoDetect.Visibility.ANY);
            mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
//            boolean result = iInstallWorkOrder.upLoadFile(listFile);
            boolean result = true;
            return new ResponseObj<>(result, null);
        } catch (Exception ex) {
            System.out.println(ex.toString());
            return new ResponseObj<>(false, null);
 
推荐文章
暴躁的石榴  ·  翻译 - Dolibarr ERP CRM Wiki
1 周前
不羁的饺子  ·  Debezium | Apache Flink
1 周前
讲道义的烈酒  ·  Debezium-JSON--流式计算 Flink版-火山引擎
1 周前
从容的大脸猫  ·  零代码第三方数据接入 | TDengine 文档 | 涛思数据
1 周前
迷茫的马克杯  ·  从VBA中的范围中删除特殊字符开发者社区
1 周前
狂野的圣诞树  ·  Excel 2003打开时,出现已丢失其VBA项目、ActiveX控件及其他任何与可编程序相关的功能! - Microsoft Community
2 年前
酒量大的小蝌蚪  ·  使用JS实现图(1)——概述 - 知乎
2 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号