软件编程
位置:首页>> 软件编程>> java编程>> 解决SpringMVC使用@RequestBody注解报400错误的问题

解决SpringMVC使用@RequestBody注解报400错误的问题

作者:Freefish1994  发布时间:2022-02-26 16:06:43 

标签:SpringMVC,@RequestBody,400

一般使用@RequestBody接收的时候报400都是传入的json字符串和对应封装的对象不对应造成的

首先要注意

封装的对象中的字段类型有没有Date类型或者int等类型的,如果有的话,在set方法中统一将传入的参数要调整为String类型

在set方法中进行参数的转换

比如有一个Date类型的字段


private Date startTime;

public Date getStartTime() {
return startTime;
}
public void setStartTime(String startTime) {
// 这里根据你的时间格式选择
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
try {
 this.startTime = dateFormat.parse(startTime);
} catch (ParseException e) {
 this.startTime = null;
}
}

这样写就可以了,不要将形参的类型写成Date类型,所以这里建议对实体类构建一个DTO,使用DTO进行封装

前台的ajax发送如下:


$.ajax({
type : "POST",
contentType : "application/json",
url : xxxxx,// 请求路径
data : JSON.stringify(data),// 将data的JSON对象转换为字符串{name:'value'}的格式
success : function(msg) {
},
error : function() {
}
});

后台的接受方法很简单


@RequestMapping(value = "XXXXX.do", method = RequestMethod.POST)
@ResponseBody
public String saveInstCorNotice(@RequestBody EntityDTO entityDTO) {

}

以前总被坑,这里记录一下!

补充知识:SpringMVC在 * 中做权限控制,解决RequestBody获取问题

做接口的权限控制,接口请求结构是JSON串,比较为难的是@RequestBody的获取

网上的资料是先手动读出来,再使用自定义的封装将JSON串写回去

感觉有点麻烦,使用了新的思路

在 * 中,拦截需要做权限验证的请求,使用下面的方式,将权限校验跳转到Controller层中做


String uri = request.getRequestURI();
request.setAttribute("referenceUrl", uri);
request.getRequestDispatcher(checkerUrl).forward(request, response);

url是用来校验权限的Controller路径

在Controller中可以使用@RequestBody注解拿到请求body,

之后可以使用获取到的body信息校验权限,

校验通过的,获取uri

再次通过如下方式,跳转到真正要请求的Controller层

request.getRequestDispatcher(uri).forward(request, response);

注意,这里会有 * 死循环的问题,当然 因为@RequestBody只能读一次的特性,在第二次被 * 拦截时就会因为请求Body为空抛异常。再当然 如果你不幸的设置了@RequestBody注解required属性为false,即允许为空 那么就真的陷入无限循环了

所以,这里我们要给request加一个标志,表明经过了该过滤器,一旦标志不为空则直接返回true 允许请求通过


if (null != flag) {
return true;
}
/*
*我想你不会将上面的代码写到 * 后面的对吧
*
*一定要将上面的代码加到 * 一开始的地方
*也不要忘记 后续设置标志位的代码
*/

解决了上面的问题可能会有请求两次的问题,这是因为将权限校验跳转到Controller层后需要

return false

否则你会发现请求执行了两次,并且在第二次抛异常:writer已经调用过

当然,这里还有一个问题,那就是权限校验的Controller层已经读取了RequestBody,那么 真正的业务逻辑Controller层怎么获取呢?

在通过校验后,将获取到RequestBody放到Request的Attribute中

在业务逻辑Controller层使用@RequestAttribute注解获取

来源:https://blog.csdn.net/qq_27762917/article/details/78296298

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com