假设有一个bean名叫TestPOJO。

1、使用ajax从前台传递一个对象数组/集合到后台。

前台ajax写法:

var testPOJO=new Array();
//这里组装testPOJO数组
$.ajax({
url:“testController/testPOJOs”,
data:JSON.stringify(testPOJO),
type:"post",
dataType:"json",
contentType:"application/json",
success:function (res) {
},
error:function(msg){
}
});

后台接收方法:

@RestController
@RequestMapping("testController")
public class testController {   @RequestMapping("/testPOJOs")
  //如果类的注解是@Controller,那么方法上面还需要加@ResponseBody,因为@ResTController=@Controller+@ResponseBody
  public String testPOJOs (@RequestBody TestPOJO [] testPOJO) {
//操作
  }   //或者下面这个
  //@RequestMapping("/testPOJOs")
  //public String testPOJOs (@RequestBody List<TestPOJO> testPOJO) {
//操作
  //}
}

无论是几维数组,前后台保持一致就行了。

2、传递Map

前台ajax写法:

var testMap={
"a":"aaa",
"b":[1,2,3]
};
$.ajax({
url:“testController/testMap”,
data:JSON.stringify(testMap),
type:"post",
dataType:"json",
contentType:"application/json",
success:function (res) {
},
error:function(msg){
}
});

后台接收方法:

@RestController
@RequestMapping("testController")
public class testController {   @RequestMapping("/testMap")
  public String testMap (@RequestBody Map<String,Object> map) {
String a = (String) map.get("a");
List<Integer> b = (List<Integer>) map.get("b");
...
  }
}

3、除了传递对象集合,还需要传递其他字段。

前台ajax写法:

var testPOJO=new Array();
//这里组装testPOJO数组
$.ajax({
url:“testController/testPOJOs”,
data:{
“strs”: JSON.stringify(testPOJO),
“others”,”…”
  },
type:"post",
dataType:"json",
success:function (res) {
},
error:function(msg){
}
});

后台接收方法:

@RestController
@RequestMapping("testController ")
public class testController {   @RequestMapping("/testPOJOs")
  public String testPOJOs (String strs,String others) { //操作使用fastjson进行字符串对象转换      List<TestPOJO> list=new ArrayList<>(); JSONObject json =new JSONObject(); JSONArray jsonArray= JSONArray.parseArray(strs); for(int i=0;i<jsonArray.size();i++){   JSONObject jsonResult = jsonArray.getJSONObject(i);   TestPOJO testPOJO=JSONObject.toJavaObject(jsonResult,TestPOJO.class); list.add(testPOJO);
}
//其他操作
  }
} 

或者直接把others和testPOJO数组重新组合一个新数组var arr=[testPOJO,”others的内容”],“strs”: JSON.stringify(arr),只传递一个strs字段就可以,然后后台转换。

4、传递一个数组

前台ajax写法:

 $.ajax({
url: 'testController/listByxxx',
data: {
"xxxs":xs//xs是一个数组
},
type: "post",
dataType: "json",
success: function (res) {}
});

后台接收方法:

 @RestController
@RequestMapping("testController")
public class testController {
@RequestMapping("/listByxxx")
public String listByxxx(@RequestParam(value = "xxxs[]")String[] xxxs){
//操作
}
}

@RequestBody一般用来处理非Content-Type: application/x-www-form-urlencoded编码格式的数据。在GET请求中,不能使用@RequestBody。在POST请求,可以使用@RequestBody和@RequestParam。

SpringMVC,SpringBoot使用ajax传递对象集合/数组到后台的更多相关文章

  1. ajax传对象或者数组到后端

    ajax是无法直接传送对象或者数组,有些人自己处理的话,能够把数据依照自己的标准连接成一个字符串,然后到后端处理.可是数据的不确定性.导致有可能会出错.并且麻烦 事实上有开源的包,能够直接解释成jso ...

  2. ajax传递list集合

    原文链接:https://blog.csdn.net/qq_37936542/article/details/79277495 一:ajax传递List<String>类型的数据 js代码 ...

  3. jquery ajax传递多个对象或数组到后台

    1.js对象创建:因为需要把对象json序列化后,才能传递到后台,后台根据json字符串进行反序列化. 2.Jquery   $.ajax方法的配置 针对$.ajax方法的配置参数需要进行修改: 1) ...

  4. springMVC中使用ajax传递json数组

    解决方法 去www.json.org下载JSON2.js 再调用JSON.stringify(JSONData)将JSON对象转化为JSON串. var people = [{ "UserN ...

  5. ajax传递对象数组

    1.Json.stringify()是将json数据格式转换成String类型字符串的方法. 后台可以使用String类型接受,接收完可以使用json转换java集合的方法. List<实体类& ...

  6. 一个实例 ---灵活使用jquery选择器实现input一个key,多个value 。 用ajax传递对象到后台控制器

    标题可能不是很清晰,我们看实例: 简单来说就是需要实现sku的功能...一件商品可以有多个属性, 一个属性可以有多个值  . 最后以json格式存到数据库 难点一: 如何实现input输入框的弹性使用 ...

  7. SpringBoot RequestBody ajax提交对象

    前端实现: var student = { "name":1, "age":2, "score":3 }; $.ajax({ url:&qu ...

  8. ajax传递对象到MVC控制器

    1.view层中ajax写法: function Add2() { var model = new Object(); model.UserName = $('#UserName').val(); m ...

  9. asp.net ajax传递Json给aspx.cs后台 webmethod方法传递json

    1.提取一个向后台写入数据的方法 ///向后台cs页面请求数据的方法 function myPost(url,data,func) { $.ajax({ type: "post", ...

随机推荐

  1. windows android ndk的某些编译工具报错乱码0x5 或拒绝访问05

    在IDEA或者AndroidStudio的快捷方式上右键属性 > 兼容性 > 以管理员身份运行 解决问题.

  2. centos7的systemd命令对比

    centos7的systemd命令对比 http://www.linuxidc.com/Linux/2014-09/106490p2.htmhttp://www.linuxidc.com/Linux/ ...

  3. 微信小程序wx.uploadFile 上传文件 的两个坑

    fileUpload: function (tempFilePath) { var that = this;//坑1: this需要这么处理 wx.uploadFile({ url: url地址, / ...

  4. 【Git】修改git远程连接ip

  5. 实现hibernate 的validator校验

    Validator校验分为快速校验和全校验.快速校验是当遇到第一个参数不符合条件时,立即停止校验程序,将校验不通过的信息返回到前端:全校验是将前端传过来的参数全部进行校验,将所有不通过校验的信息一起返 ...

  6. tensorflow(4)踩过的一些坑

    版本问题 1.1 版本的一个BUG ValueError: Variable rnn/basic_lstm_cell/weights already exists, disallowed. 结合这个文 ...

  7. vue移动端适配

    https://www.w3cplus.com/mobile/vw-layout-in-vue.html

  8. 关于常用mysql的文件

    这个一般在做项目的时候会用到,直接建立函数啥的,后部直接调用 代码: class_database.py import pymysql SERVER_HOST = "192.168.1.1& ...

  9. 客户端不能连接MySQL - 2003-Can't connect to MySQL server on '192.168.43.180'(10060 "Unknown error")

    客户端不能连接MySQL 场景: 数据库(此处以MySQL为例)安装在虚拟机里面,在宿主机上进行连接数据库的时候始终不能连接,但在虚拟机中使用正常. 针对上面的场景: 1. 在虚拟机里面可以正常使用M ...

  10. 1.1大数据平台架构及Hadoop生态圈

    1.硬件架构实例 2.软件架构实例 3.数据流通用概念模型 a.数据源(互联网.物联网.企业数据):App.Device.Site b.数据收集(ETL.提取.转换.加载):Flume.Kafka.S ...