@RequestBody注解的使用场景解析

时间:2023-02-01 09:59:26


最近在做一个项目的过程中,碰到前端传过来有值,后端接收不到,开始还以为是属性名不一致导致的,反复检查也没找到属性名不一致的问题,后面才发现问题所在,先上图:

@RequestBody注解的使用场景解析

前端是通过json穿过来的一个对象,后端代码如下:

@RequestBody注解的使用场景解析

后来改成如下代码:

@RequestBody注解的使用场景解析

以前最开始使用mvc时没太留意这个区别,找资料后整理@Requesbody的用法区别如下:

1 GET、POST方式提交时, 根据 request header Content-Type 的值来判断:
1.1application/x-www-form-urlencoded:可选(即非必须,因为这种情况的数据 @RequestParam, @ModelAttribute 也可以处理,当然@RequestBody也能处理);

1.2multipart/form-data:不能处理(即使用@RequestBody不能处理这种格式的数据)

1.3其他格式:必须(其他格式包括application/json, application/xml等。这些格式的数据,必须使用@RequestBody来处理);

2 PUT 方式提交时, 根据request header Content-Type的值来判断:
2.1 application/x-www-form-urlencoded:必须;

2.2 multipart/form-data:不能处理;

2.3 其他格式:必须;