当前位置:网站首页>@RequestBody和@RequestParam区别
@RequestBody和@RequestParam区别
2022-07-31 08:22:00 【Asy9023】
@RequestBody
@RequestBody主要⽤来接收前端传递给后端的json字符串中的数据的(请求体中的数据的);GET⽅式⽆请求体,所以使⽤@RequestBody接收数据时,前端不能使⽤GET⽅式提交数据,⽽是⽤POST⽅式进⾏提交。在后端的同⼀个接收⽅法⾥,@RequestBody与@RequestParam()可以同时使⽤,@RequestBody最多只能有⼀个,⽽@RequestParam()可以有多个。
@RequestBody接收的参数是来⾃requestBody中,即请求体。⼀般⽤于处理⾮Content-Type: application/x-www-form-urlencoded编码格式的数据,⽐如:application/json、application/xml等类型的数据。
GET请求中,因为没有HttpEntity,所以@RequestBody并不适⽤。
POST请求中,通过HttpEntity传递的参数,必须要在请求头中声明数据的类型Content-Type,SpringMVC通过使⽤HandlerAdapter 配置来解析HttpEntity 中的数据,然后绑定到相应的bean上。
如果前端向后端传递的是非实体类对象,后台也可以使⽤@RequestBody注解,那就用List<Map<String, String>>来接收
@RequestParam
⽤来处理Content-Type: 为 application/x-www-form-urlencoded编码的内容。(Http协议中,如果不指定Content-Type,则默认传递的参数就是application/x-www-form-urlencoded类型)
POST类型和GET类型都可以使⽤@RequestParam注解来接收参数
@RequestParam注解有三个参数
required表⽰是否必须,默认为true,必须。
defaultValue可设置请求参数的默认值,如果设置了该值,required=true将失效,⾃动为false,如果没有传该参数,就使⽤默认值。
value为接收url的参数名(相当于key值)。
总结
1.Post请求接收@RequestBody修饰的参数和@RequestParam修饰的参数,而Get请求则只能接收@RequestParam修饰的参数。
2.如果前端传的是Json类型的对象,后台就要使用@RequestBody修饰的实体类接收,如果是单个属性就使用@RequestParam修饰的变量或实体类。
边栏推荐
猜你喜欢
[Yellow ah code] Introduction to MySQL - 3. I use select, the boss directly drives me to take the train home, and I still buy a station ticket
Open Source | Commodity Recognition Recommender System
[转载] Virtual Studio 让系统找到需要的头文件和库
SSM框架讲解(史上最详细的文章)
MySQL安装教程
【Unity】编辑器扩展-02-拓展Hierarchy视图
【Unity】编辑器扩展-03-拓展Inspector视图
【插值与拟合】
Regarding "computing power", this article is worth reading
一、MySQL主从复制原理
随机推荐
Doraemon teach you forwarded and redirect page
Flutter Paystack 所有选项实现
刷题《剑指Offer》day05
MySQL安装教程
【云原生&微服务五】Ribbon负载均衡策略之随机ThreadLocalRandom
First acquaintance with NK-RTU980 development board
C# 正则表达式汇总
Failure scenarios of @Transactional annotations
科目三:前方路口直行
Vue项目通过node连接MySQL数据库并实现增删改查操作
2022/7/30 考试总结
【MySQL功法】第3话 · MySQL中常见的数据类型
How to Install MySQL on Linux
数组every和some方法的区别?
【小程序项目开发-- 京东商城】uni-app之商品列表页面 (上)
【黄啊码】MySQL入门—3、我用select ,老板直接赶我坐火车回家去,买的还是站票
MySQL中InnoDB的多版本并发控制(MVCC)的实现
蚂蚁核心科技产品亮相数字中国建设峰会 持续助力企业数字化转型
SQL 入门之第一讲——MySQL 8.0.29安装教程(windows 64位)
skynet中一条消息从取出到处理完整流程(源码刨析)