@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 属性。
|