@RequestBody使用中的一些细节
-
@RequestBody
主要是用来接受前端传递给后端的json字符串中的数据(请求体中的数据);而且最常用的请求体传参无疑是POST
请求,所以使用@RequestBody
接受数据时,一般都用POST
方式进行提交。在后端的同一个接受方法里,@RequestBody
与@RequestParam()
可以同时使用,@RequestBody
最多只能有一个,@RequestParam()
可以有多个。 -
后端
@RequestBody
注解对应的类将在HTTP的输入流(含请求体)装配到目标类(即:@RequestBosy
后面的类)时,会根据json
字符串中的key
来匹配对应实体类的属性,如果匹配一致且json
中的该key对应的值符合(或可转换为)实体类的对应属性的类型时,会调用实体类的setter
方法将值赋给该属性。 -
json
字符串中,如果value为""
的话,后端对应属性如果是String
类型,那么接受就是""
,如果后端属性是Integer
、Double
等类型,那么接收到的就是null
。 -
json
字符串中,如果value
为null
的话,后端对应接受就是null
。 -
如果某个参数没有
value
的话,在传json
字符串给后端时,要么干脆就不把该字段写到json
字符串中;要么写value
时,必须有值,null
或""
都行。千万不能有类似statu:,
这样的写法。 -
一些补充的结论:
-
@JsonAlias
注解,实现json
转模型时,使json
中的特定key
能转化为特定的模型属性;但是模型转json
时,对应的转换后的key
仍然与属性名一致。
-
@JsonProperty
注解,实现:json
转模型时,使json
中的特定key
能转化为指定的模型属性;同样的,模型转json
时,对应的转换后的key
为指定的key
。 -
@JsonAlias
注解需要依赖于setter
、getter
,而@JsonProperty
不需要; -
在不考虑上述两个注解的一般情况下,
key
与属性匹配时,默认大小写敏感; -
有多个相同的
key
的json
字符串中,转换为模型时,会以相同的几个key
中,排在最后的那个key
的值给模型属性复制,因为setter
会覆盖原来的值。见示例中的gender
属性。
-