【无标题】Java使用@RequestBody和@RequestParam注意事项

@RequestBody和RequestParam区别、使用

  • 1、@RequestBody主要用来接收前端传递给后端的json字符串中的数据的(请求体中的数据的);
  • 2、GET方式无请求体,所以使用@RequestBody接收数据时,前端不能使用GET方式提交数据,而是用POST方式进行提交;
  • 3、在后端的同一个接收方法里,@RequestBody与@RequestParam()可以同时使用,@RequestBody最多只能有一个,而@RequestParam()可以有多个;

注意事项


1、如果参数时放在请求体中,传入后台的话,那么后台要用@RequestBody才能接收到;如果不是放在 请求体中的话,那么后台接收前台传过来的参数时,要用@RequestParam来接收;
2、如果参数前写了@RequestParam(xxx),那么前端必须有对应的xxx名字才行(不管其是否有值,当然可以通过设置该注解的required属性来调节是否必须传),如果没有xxx名的话,那么请求会出错,报400;
3、如果后端参数是一个对象,且该参数前是以@RequestBody修饰的,那么前端传递json参数时,必须满足以下要求:
a:后端@RequestBody注解对应的类在将HTTP的输入流(含请求体)装配到目标类时,会根据json字符串中的key来匹配对应实体类的属性;
b:json字符串中,如果value为"“的话,后端对应属性如果是String类型的,那么接受到的就是”“,如果是后端属性的类型是Integer、Double等类型,那么接收到的就是null;
c:json字符串中,如果value为null的话,后端对应收到的就是null;
d:如果某个参数没有value的话,在传json字符串给后端时,要么干脆就不把该字段写到json字符串中;要么写value时, 必须有值,null 或”“都行。千万不能有类似"stature”:


示例:

使用@RequestBody 可接受的参数 String, Map,JSONObject,或者对应的JavaBean
	@PostMapping("/test")
	@ApiOperation("xxx")
	@NoRepeatSubmit
	public Object test(@RequestBody TechnicalWhiteImgRequest technicalWHiteImgRequest) {
		return null;
	}

/**
 * @author : liudy23
 * @date : 2023/1/6
 */
@Data
@ApiModel("xxx请求参数")
public class TechnicalWhiteImgRequest implements Serializable {

    private static final long serialVersionUID = -3138667394788394672L;

    @ApiModelProperty("xxxDTO")
    private List<TechnicalWhiteImgDTO> technicalWhiteImgList;

    @ApiModelProperty("xxx附件信息")
    private List<SysFile> fileList;

    @ApiModelProperty("xxx类型")
    private Integer type;
}



/**
 * @author : liudy23
 * @date : 2023/1/6
 */
@Data
@ApiModel("xxxDTO")
public class TechnicalWhiteImgDTO implements Serializable {

    private static final long serialVersionUID = -7632140699343700141L;

    @ApiModelProperty("xxx主键id")
    private Integer id;

    @ApiModelProperty("xxx数量")
    private Integer upNum;

    @ApiModelProperty("xxx交接人")
    private Integer aUserId;

    @ApiModelProperty("xxx被交接人")
    private Integer bUserId;

}
@GetMapping("/test")
@ApiOperation("测试")
public Tip<String> test(@RequestParam String id) {
	return null;
}

@RequestMapping(value = "/getUserInfo")
public User getUserInfo(@RequestParam(value = "id",required = false) Integer id){
}

知识点

  • Get和Post都是Http协议的组件,所以底层都是使用tcp链接。Get的请求方式是将http的header和data一并发往服务端,也就是一条tcp数据包发送,这就会有两个问题:数据量有限,依赖于Tcp负载能力,所以携带的数据量很大的情况下,容易造成重发。有的携带的数据只能接受转化成ASCII字符。但是Post不一样,post使用两步走,先发送http的header,然后再传输data。数据类型也不受限制。而且数据隐秘性比较好
  • get请求方式参数是拼接在url后,所以限制了可以发送的长度。Get不支持使用http Body获取参数,他只支持params,也就是URL拼接参数
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值