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

 更新时间:2020年09月28日 09:46:57   作者:Freefish1994  
这篇文章主要介绍了解决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注解获取

以上这篇解决SpringMVC使用@RequestBody注解报400错误的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • java并发编程之原子性、可见性、有序性

    java并发编程之原子性、可见性、有序性

    这篇文章主要给大家分享的是java并发编程的原子性、可见性和有序性,文章会具体举例说明,感兴趣的小伙伴可以参考一下文章的具体内容
    2021-09-09
  • 详解Mybatis的分页插件

    详解Mybatis的分页插件

    这篇文章主要介绍了详解Mybatis的分页插件,在 Mybatis中,如何对数据进行分页是一个非常常见的问题,现在,我们可以通过使用 Mybatis 的分页插件来实现对数据的分页,需要的朋友可以参考下
    2023-05-05
  • java利用多线程和Socket实现猜拳游戏

    java利用多线程和Socket实现猜拳游戏

    这篇文章主要为大家详细介绍了java利用多线程和Socket实现猜拳游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • Spring TransactionalEventListener事务未提交读取不到数据的解决

    Spring TransactionalEventListener事务未提交读取不到数据的解决

    这篇文章主要介绍了Spring TransactionalEventListener事务未提交读取不到数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • 详解Spring工厂特性

    详解Spring工厂特性

    今天带大家学习Spring的特性-工厂特性,文中有非常详细的介绍及代码示例,对正在学习java的小伙伴们有很好地帮助,需要的朋友可以参考下
    2021-05-05
  • 谈谈Hashmap的容量为什么是2的幂次问题

    谈谈Hashmap的容量为什么是2的幂次问题

    这篇文章主要介绍了谈谈Hashmap的容量为什么是2的幂次问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • springboot拦截器过滤token,并返回结果及异常处理操作

    springboot拦截器过滤token,并返回结果及异常处理操作

    这篇文章主要介绍了springboot拦截器过滤token,并返回结果及异常处理操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Java对象和Json文本转换工具类的实现

    Java对象和Json文本转换工具类的实现

    Json 是一个用于Java对象和Json文本相互转换的工具类,本文主要介绍了Java对象和Json文本转换工具类,具有一定的参考价值,感兴趣的可以了解一下
    2022-03-03
  • SpringBoot+MQTT+apollo实现订阅发布功能的示例

    SpringBoot+MQTT+apollo实现订阅发布功能的示例

    这篇文章主要介绍了SpringBoot+MQTT+apollo实现订阅发布功能的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • java实现图片转ascii字符画的方法示例

    java实现图片转ascii字符画的方法示例

    这篇文章主要介绍了java实现图片转ascii字符画的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08

最新评论