$.post发送json数据时,后台@RequestBody转化实体类,返回415错误,原因及解决方案

版权声明:转载请注明作者:sust_ly https://blog.csdn.net/pycharm_u/article/details/86624350

前端使用Ajax请求时,使用$.post

//http 415转换错误,待解决
            $("#passWord").blur(function () {
                var url="http://localhost:8082/checkPassWord";
                var name = $("#userName").val();
                var pass = this.value;
                var param={id:name,password:pass};
                $.post(url, param, function (data) {
                    if(data.isSuccess == true){
                        $("#userMsg").text("");
                    }else {
                        $("#userMsg").text(data.Msg).css({"color":"red"});
                    }
                },"json");
            });

 

如果后台使用

   @ResponseBody
    @RequestMapping(value = "/checkPassWord", method = RequestMethod.POST)
    public Map<String, Object> checkPassWord(@RequestBody TeacherInfo teacherInfo){
        String passowrd = teacherService.findPassowrdByid(teacherInfo.getId());
        Map<String, Object> map = new HashMap<String, Object>();
        if (!passowrd.equals(teacherInfo.getPassword())){
            map.put("isSuccess",false);
            map.put("Msg","密码不正确!");
        }else {
            map.put("isSuccess",true);
        }
        return map;
    }

这样子,就会出现415错误

HTTP Status 415 – Unsupported Media Typ

这个就是后台无法解析请求数据,后台要求是一个json数据,前端按理说传的也是json数据,那为什么解析出错呢?

从他的报文头我们可以看出,请求数据是一个x-www-form-urlencoded类型,而不是json格式,这样后台就无法解析了。

解决方案

1.使用@RequestParam

使用这个注解将前端请求的数据一个一个的取出来。

2.使用$.ajax

设置contentType为application/json; charset=UTF-8

3.设置$.post的contentType为application/json; charset=UTF-8

百度了很久没有找见,若读者找见了,麻烦给楼主留言,谢谢

猜你喜欢

转载自blog.csdn.net/pycharm_u/article/details/86624350
今日推荐