文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SpringMVC参数的传递之如何接收List数组类型的数据

2022-11-13 18:54

关注

前言

本文主要是记录SpringMVC中当前台传过来数组的时候,如何把前台传过来的数据封装到Controller层方法的形参中。

在了解下面参数如何传递前先记住两个结论

1.前台发送String和基本类型数组

前台数据的发送(发送json对象(或js对象)

$(function () {
    var obj={};
    obj.name="李四";
    obj.nums=[1,2,3];
    $.ajax({
        url: "/param/test1",
        type:"POST",
        contentType:"application/x-www-form-urlencoded",
        data:obj,
        dataType:"json",
        success:function(data){
        }
    })
})

后台接收数据

后台接收数据时的形参必须和前台表单里的字段名一样(如果不一致要使用@RequestParam声明,数组必须声明)

 	@RequestMapping(value = "/test1", method = RequestMethod.POST)
    @ResponseBody
    private String Test1(String name,@RequestParam("nums[]") Integer[] nums) {
        System.out.println(name);
        for(int i=0;i<nums.length;i++){
            System.out.println(nums[i]);
        }
        return "success";
    }

当然,也可以使用List来接收

	@RequestMapping(value = "/test1", method = RequestMethod.POST)
    @ResponseBody
    private String Test1(String name,@RequestParam("nums[]") List<Integer> nums) {
        System.out.println(name);
        System.out.println(nums);
        return "success";
    }

对于上面的这两种接收方式只适用于接收基本类型或包装类型的数组。

2.前台发送String类型和对象数组

一些将要使用的类

public class User {
    private String name;
    private int age;
	//getter and setter...
}
public class StringAndList {
    private List<User> users;
    private String name;
	//getter and setter...
}

前端发送json字符串(注意:这里使用application/json

$(function () {
    var obj={};
    obj.name="展示";
    var user1={"name":"李四","age":1};
    var user2={"name":"网四","age":23};
    obj.users=[];
    obj.users.push(user1);
    obj.users.push(user2);
    var s=JSON.stringify(obj);
    $.ajax({
        url: "/param/test1",
        type:"POST",
        contentType:"application/json",//注意编码格式
        data:JSON.stringify(obj),//"{"name":"展示","users":[{"name":"李四","age":1},{"name":"网四","age":23}]}"

        dataType:"json",
        success:function(data){
        }
    })
})

后台接收数据

一个方法中只允许有一个@RequestBody修饰的参数(此时方法中只可以有一个形参),它实际上是将输入流的body体作为一个整体进行转换,而body整体只有一份,解析完成之后会关闭输入流。

如果传入多个参数则会报错,除非自定义参数解析器。

所以当我们既要接收String参数,又要接收对象数组的时候,我们只能把这两个参数封装在一个自定义类中。

	@RequestMapping(value = "/test1", method = RequestMethod.POST)
    @ResponseBody
    private String Test1(@RequestBody StringAndList sal) {
        System.out.println(sal);
        return "success";
    }

前面不是说可以使用Map来接收数据吗,那使用Map来接收的数据是怎么样的呢?

我们来试试

	@RequestMapping(value = "/test1", method = RequestMethod.POST)
    @ResponseBody
    private String Test1(@RequestBody Map<String,Object> map) {
        return "success";
    }

通过debug,我们可以发现map保存的数据是什么(我们可以把传过来的json对象中的属性-值想象成一个个key-value,就不难理解为什么可以用Map接收了)

3.前台只发送对象数组

上面展示了同时接收其他类型和对象数组的情况,那么如果只接收对象数组呢?

前端发送json字符串

$(function () {
    var obj=[];
    var user1={"name":"李四","age":1};
    var user2={"name":"网四","age":23};
    obj.push(user1);
    obj.push(user2);
    var s=JSON.stringify(obj);//"[{"name":"李四","age":1},{"name":"网四","age":23}]"
    $.ajax({
        url: "/param/test1",
        type:"POST",
        contentType:"application/json",
        data:JSON.stringify(obj),
        dataType:"json",
        success:function(data){
        }
    })
})

后台接收数据

因为只要接收数组,所以不用自定义一个类来封装数据

	@RequestMapping(value = "/test1", method = RequestMethod.POST)
    @ResponseBody
    private String Test1(@RequestBody List<User> users) {//参数名任意
        System.out.println(users);
        return "success";
    }

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯