SpringMVC 获取前台传来的数组

1、前端假设使用如下url进行ajax请求:假http://ip:port/ap/aa.jsp?a=1&a=2

      或者,使用如下表单提交:

      <form action="" method="post">

<input name="a" type="text" value="1">

<input name="a" type="text" value="2">

      <form>

然后你在 java里面写这样的String[] a = arg0.getParameterValues("a")代码 , 那么java里面的这个a的字符集合里面就是[1,2]


2、后端也可以使用springmvc的如下方式获取:

public String xxx(@RequestParam("a") String[] params){
..
}


2、使用springmvc 的requestBody接受ajax传来的数组、json对象:

1)controller:

public ResultMessage deleteConbineCode(@RequestBody Long[] id) {
		Map queryMap = new HashMap();
		queryMap.put("id", id);
		try {
			CombineCodeService.deleteConbineCode(queryMap);
			return new ResultMessage(0, "删除成功!");
		} catch (Exception e) {
			e.printStackTrace();
			logger.error(e.getMessage());
			return new ResultMessage(-1, "删除失败!");
		}
	}

2)前端:

var ids = [];
                    for(var i=0;i<rows.length;i++){
                    	alert(rows[i].id);
                        ids.push(rows[i].id);
                    }
					$.ajax({
						type : "post",
						contentType : "application/json;charset=UTF-8",
						url : "<%=basePath %>combineCode/deleteConbineCode",
						dataType : "json",
						processData : false,
						data : $.toJSONString(ids),
						success : function(_data) {
							if(_data.status==0) {
								$("#code_grid").datagrid('reload');
							}
						}
					});

实例二:

1)java

public class AjaxController {
	
	/**
	 * 接收客户端发送的JSON数据,并将其转换为对象
	 * @RequestBody 
	 * 其一,从http请求报文的请求体中获取JSON数据,则说明必须是POST请求
	 * 其二,Body中为JSON,则最可能为Ajax请求,通过form进行post请求好像办不到呢
	 */
	@RequestMapping(value="jsonPost", method=RequestMethod.POST, consumes="application/json")
	@ResponseBody
	public User jsonPost(@RequestBody User user) {
		System.out.println("ajax json post");
		System.out.println(user.getName());
		System.out.println(user.getPassword());
		user.setName("李四");
		user.setPassword("100");
		return user;
	}
}

2)前端:

var user = {};
			user.name = $("#name").val();
			user.password = $("#password").val();
			var jsonStr = JSON.stringify(user);
			//var json2Object = JSON.parse(jsonStr);
			$.ajax({
				type : "post",
				contentType : "application/json;charset=UTF-8",
				url : "jsonPost",
				dataType : "json",
				processData : false,
				data : jsonStr,
				success : function(msg) {
					//javascript已自动将返回的json数据转为对象了
					alert("success:"+msg.name+"---"+msg.password);
				},
				error : function() {
					alert("try again!");
				}
			});


  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赶路人儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值