Spring MVC无法正确接收From表单参数的解决方案

 更新时间:2025年12月11日 15:05:44   作者:湛耀  
文章描述了在处理Spring Boot中的表单提交时遇到的JSON解析错误,并通过分析代码和HTTP请求的contentType,解释了错误的原因,主要内容包括了ajax请求中contentType的设置以及@RequestBody注解的作用,最后给出了具体的解决办法

问题描述

先看有问题的代码:

controller:

@ResponseBody
@PostMapping(value = "/addUser")
public String addUser(@RequestBody AdminPersonVo adminPersonVo) {

    return "success";
}

js:

$(form).ajaxSubmit({
    url:"/addUser",
    type:"POST",
    contentType: 'application/json;charset=utf-8',
    filtering: function(el, index) {
        if ( !$(el).hasClass('ignore') ) {
            return el;
        }
    },
    success: function (data) {
        alert(data);
    }
});

表单提交报错如下:

.w.s.m.s.DefaultHandlerExceptionResolver : Resolved [org.springframework.http.converter.HttpMessageNotReadableException: JSON parse error: Unrecognized token 'name': was expecting 'null', 'true', 'false' or NaN; nested exception is com.fasterxml.jackson.core.JsonParseException: Unrecognized token 'name': was expecting 'null', 'true', 'false' or NaN​

错误信息大概意思是: jackson 无法正确解析 json 。

开始踏上寻找解决之路……

看完上面代码能看出问题所在的话可以不用往下面看了

知识要点

要点一

ajax请求中的 contentType: ‘application/json;charset=utf-8’ 如果不加的话,会报如下错误:

.w.s.m.s.DefaultHandlerExceptionResolver : Resolved [org.springframework.web.HttpMediaTypeNotSupportedException: Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported]

表达意思也很清晰,默认的请求参数类型是: application/x-www-form-urlencoded;charset=UTF-8,而现在的代码不支持这种类型的参数请求。

要点二

聚焦 @RequestBody 这个注解。

@RequestBody 注解常用来处理 content-type 不是默认的 application/x-www-form-urlencoded 编码的内容,比如说:application/json 或者是 application/xml 等。

这就是为什么代码不支持 application/x-www-form-urlencoded 的原因。

解决办法

将 controller 中的 @RequestBody 去掉,将 JS 中的 contentType: ‘application/json;charset=utf-8’ 去掉,就能正常接收参数了

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • spring+shiro 整合实例代码详解

    spring+shiro 整合实例代码详解

    本文通过实例代码给大家介绍spring+shiro 整合的过程,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-10-10
  • ActiveMQ持久化机制代码实例

    ActiveMQ持久化机制代码实例

    这篇文章主要介绍了ActiveMQ持久化机制代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • MyBatis-Plus 与Druid 数据源操作

    MyBatis-Plus 与Druid 数据源操作

    SpringBoot框架集成MyBatis-Plus和Druid数据源,简化了数据操作与监控,MyBatis-Plus作为MyBatis的增强工具,自动实现CRUD操作,减少手写SQL,提供分页、逻辑删除等功能,本文介绍MyBatis-Plus & Druid 数据源总结,感兴趣的朋友一起看看吧
    2024-09-09
  • 解决IDEA报错Caused by: org.springframework.boot.web.server.WebServerException: Unable to start embedded

    解决IDEA报错Caused by: org.springframework.boot.web.se

    遇到IDEA启动报错,可尝试以下方法:打开项目设置(Ctrl+Shift+Alt+S),将JDK版本修改为1.8;或者检查TomCat依赖,若有问题可尝试删除,此外,确保每次拉取项目后,maven地址设置为本地,并且JDK版本设置为1.8,以上为个人解决经验,希望对大家有所帮助
    2024-09-09
  • Java使用volatile关键字的注意事项

    Java使用volatile关键字的注意事项

    volatile关键字是Java中的一种稍弱的同步机制,为什么称之为弱机制。这篇文章主要介绍了Java使用volatile关键字的注意事项,需要的朋友可以参考下
    2017-02-02
  • Java程序去调用并执行shell脚本及问题总结(推荐)

    Java程序去调用并执行shell脚本及问题总结(推荐)

    这篇文章主要介绍了Java程序去调用并执行shell脚本及问题总结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • Java中try-with-resources使用教程

    Java中try-with-resources使用教程

    try-with-resources是Java7引入的一种资源管理机制,用于自动关闭实现了AutoCloseable接口的资源,避免资源泄漏,提升代码安全性和简洁性,下面就来介绍一下使用小结,感兴趣的可以了解一下
    2026-01-01
  • SpringBoot2.7 WebSecurityConfigurerAdapter类过期配置

    SpringBoot2.7 WebSecurityConfigurerAdapter类过期配置

    这篇文章主要为大家介绍了SpringBoot2.7中WebSecurityConfigurerAdapter类过期应该如何配置,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • spring boot 监听容器启动代码实例

    spring boot 监听容器启动代码实例

    这篇文章主要介绍了spring boot 监听容器启动代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • 浅谈@RequestParam 参数是否必须传的问题

    浅谈@RequestParam 参数是否必须传的问题

    这篇文章主要介绍了浅谈@RequestParam 参数是否必须传的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02

最新评论