解决SpringMVC使用@RequestBody注解报400错误的问题
一般使用@RequestBody接收的时候报400都是传入的json字符串和对应封装的对象不对应造成的
首先要注意
封装的对象中的字段类型有没有Date类型或者int等类型的,如果有的话,在set方法中统一将传入的参数要调整为String类型
在set方法中进行参数的转换
比如有一个Date类型的字段
privateDatestartTime; publicDategetStartTime(){ returnstartTime; } publicvoidsetStartTime(StringstartTime){ //这里根据你的时间格式选择 SimpleDateFormatdateFormat=newSimpleDateFormat("yyyy-MM-dd"); try{ this.startTime=dateFormat.parse(startTime); }catch(ParseExceptione){ 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 publicStringsaveInstCorNotice(@RequestBodyEntityDTOentityDTO){ }
以前总被坑,这里记录一下!
补充知识:SpringMVC在拦截器中做权限控制,解决RequestBody获取问题
做接口的权限控制,接口请求结构是JSON串,比较为难的是@RequestBody的获取
网上的资料是先手动读出来,再使用自定义的封装将JSON串写回去
感觉有点麻烦,使用了新的思路
在拦截器中,拦截需要做权限验证的请求,使用下面的方式,将权限校验跳转到Controller层中做
Stringuri=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){ returntrue; } /* *我想你不会将上面的代码写到拦截器后面的对吧 * *一定要将上面的代码加到拦截器一开始的地方 *也不要忘记后续设置标志位的代码 */
解决了上面的问题可能会有请求两次的问题,这是因为将权限校验跳转到Controller层后需要
returnfalse
否则你会发现请求执行了两次,并且在第二次抛异常:writer已经调用过
当然,这里还有一个问题,那就是权限校验的Controller层已经读取了RequestBody,那么真正的业务逻辑Controller层怎么获取呢?
在通过校验后,将获取到RequestBody放到Request的Attribute中
在业务逻辑Controller层使用@RequestAttribute注解获取
以上这篇解决SpringMVC使用@RequestBody注解报400错误的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。