首先出现这种情况是因为有下面这种需求


  1. $.ajax({
  2. type: "POST",
  3. url: "${pageContext.request.contextPath}/courses",
  4. data: JSON.stringify({
  5. course:course,
  6. courseInfoList:courseInfoList
  7.        }),//将对象序列化成JSON字符串
  8. dataType:"json",
  9. contentType : 'application/json;charset=utf-8', //设置请求头信息
  10. success: function(data){
  11. },
  12. error: function(res){
  13. }
  14. });

也就是在ajax传输数据时有多种数据类型在data域中

从而就会有下面这种controller


  1. @RequestMapping(method = RequestMethod.POST ,consumes = "application/json")
  2. public String createCourse(@RequestBody Course course, @RequestBody List<CourseInfo> courseInfoList)
  3. {
  4. System.out.println(coursePackage.getCourse());
  5. System.out.println(coursePackage.getCourseInfoList());
  6. return "/createCourse";
  7. }

这样就会出现400错误,服务器无法理解这个请求

原因:

@requestbody的含义是在当前对象获取整个http请求的body里面的所有数据,因此spring就不可能将这个数据强制包装成Course或者List类型,并且从@requestbody设计上来说,只获取一次就可以拿到请求body里面的所有数据,就没必要出现有多个@requestbody出现在controller的函数的形参列表当中

如果想解决这种问题

1.新建一个包装上面两种entity的entity类:


  1. package com.yyc.entity;
  2. import java.util.List;
  3. public class CoursePackage {
  4. public CoursePackage() {
  5. // TODO Auto-generated constructor stub
  6. }
  7. private Course course;
  8. private List<CourseInfo> courseInfoList;
  9. public void setCourse(Course course)
  10. {
  11. this.course = course;
  12. }
  13. public void setCourseInfoList(List<CourseInfo> courseInfoList)
  14. {
  15. this.courseInfoList = courseInfoList;
  16. }
  17. public Course getCourse()
  18. {
  19. return course;
  20. }
  21. public List<CourseInfo> getCourseInfoList()
  22. {
  23. return courseInfoList;
  24. }
  25. }

然后将controller函数改为


  1. @RequestMapping(method = RequestMethod.POST ,consumes = "application/json")
  2. public String createCourse(@RequestBody CoursePackage coursePackage,Model model)
  3. {
  4. System.out.println(coursePackage.getCourse());
  5. System.out.println(coursePackage.getCourseInfoList());
  6. return "/createCourse";
  7. }

但是这样又显得比较不够简洁

2..用Map<String, Object>接受request body,自己反序列化到各个entity中。

例:下面这篇博客比较好:https://www.cnblogs.com/mahuan2/p/6008832.html

原文地址:https://blog.csdn.net/qq_34608620/article/details/80635139

controller函数中参数列表使用多个@RequestBody的更多相关文章

  1. php获取当前被调函数的参数列表

    下面是php中的一个获取当前别调用函数的参数列表的测试程序,感受一下php类库的强大之处: // 测试获取参数列表 getArgs('aaa', 'bbb', 'ccc', 123, true); f ...

  2. PHP函数可变参数列表的具体实现方法介绍

    PHP函数可变参数列表可以通过_get_args().func_num_args().func_get_arg()这三个函数来实现.我们下面就对此做了详细的介绍. AD:2014WOT全球软件技术峰会 ...

  3. php实现函数可变参数列表

    使用func_get_args().func_num_args().func_get_arg() 可以构造一个可变参数列表的函数. 首先大致介绍以上三个函数. (1)array func_get_ar ...

  4. Python之在函数中使用列表作为默认参数

      本文将介绍笔者在工作中遇到的Python的一个坑,那就是使用列表作为默认参数.   我们知道,在Python中,列表(list)是可变对象,所以列表的内容可能会在函数内改变.另一个需要注意的是,使 ...

  5. python函数中把列表(list)当参数时的"入坑"与"出坑"

    在Python函数中,传递的参数如果默认有一个为 列表(list),那么就要注意了,此处有坑!! 入坑 def f(x,li=[]): for i in range(x): li.append(i*i ...

  6. Python在函数中使用列表作为默认参数

    在学习中遇到的Python的一个坑,那就是使用列表作为默认参数. 我们知道,在Python中,列表(list)是可变对象,所以列表的内容可能会在函数内改变.另一个需要注意的是,使用列表作为函数的默认参 ...

  7. day11 函数的参数列表

    """ 今日内容: 1.函数参数的分类 2.形参是对实参的值拷贝 3.实参的分类 4.形参的分类 5.打散机制 附1:字符串的比较 """ ...

  8. Python函数中的列表

    在看21天的Python书中写出了一个陷阱,但没给出解释,以下为代码陷阱

  9. python学习Day11 函数的参数列表

    复习 什么是函数? 具体特定功能的代码块 - 特定功能代码作为一个整体,并给该整体命名,就是函数 函数的优点 : 1.减少代码的冗余,2.结构清晰,可读性强 3.具有复用性,开发效率高,维护成本高 如 ...

随机推荐

  1. mysql DEFAULT约束 语法

    mysql DEFAULT约束 语法 作用:用于向列中插入默认值. 说明:如果没有规定其他的值,那么会将默认值添加到所有的新记录.直线电机 mysql DEFAULT约束 示例 //在 "P ...

  2. [CF1093E]Intersection of Permutations:树套树+pbds

    分析 裸的二维数点,博主用树状数组套平衡树写的,顺便pbds真好用. Update on 2018/12/20:再解释一下为什么是二维数点,第一维是\(la \leq i \leq ra\),第二维是 ...

  3. 多项式总结(unfinished)

    试试以二级标题为主的格式. 多项式相关 注:本篇博客不包含\(FFT\)基础姿势.如果您想要阅读本篇博客,请确保自己对\(FFT,NTT\)有基本的认识并且能够独立写出代码. 多项式是什么? 左转数学 ...

  4. 170831-关于JdbcTemplate声明式事务-操作步骤-例子

    创建一个动态web工程 加入jar包 3.创建一份jdbc.properties文件 4.在spring配置文件中配置数据源 5.测试数据源: 6.配置jdbcTemplate: 7.创建Dao类 & ...

  5. POJ 1384 Piggy-Bank (完全背包)

    Piggy-Bank 题目链接: http://acm.hust.edu.cn/vjudge/contest/130510#problem/F Description Before ACM can d ...

  6. maven入门问题解决

    记录入门使用maven的问题和解决方法: 一.用mvn clean compile编译报错/ 或者在IDE中编译时,Problem视图显示错误:无法从maven服务器或者私有服务器或者某个网站中中下载 ...

  7. 前端每日实战:142# 视频演示如何用 CSS 的 Grid 布局创作一枚小鸡邮票

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/mGZbmQ 可交互视频 此视频是可 ...

  8. justify-content

    CSS3弹性布局内容对齐(justify-content)属性使用详解 内容对齐(justify-content)属性应用在弹性容器上,把弹性项沿着弹性容器的主轴线(main axis)对齐. 该操作 ...

  9. 在Linux环境中运行python 项目

    1首先创建一个虚拟环境或者在一个已有的虚拟环境中创建一个django项目 1.1 创建一个虚拟环境: mkvirtualenv my_django115 这会在 ~/Envs 中创建 my_djang ...

  10. fedora23然后创建workspace?或者说是panel面板?

    好像在fedora23中 无法再添加工作空间workspace. 系统会自动的在非空工作空间后面再生成一个空的工作空间. 而且 工作空间 好像不只 4个, 可以有很多个. panel面板好像也不能添加 ...