现在的位置: 首页 > 综合 > 正文

SpringMVC 获取前台传来的数组

2018年05月07日 ⁄ 综合 ⁄ 共 1919字 ⁄ 字号 评论关闭

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!");
				}
			});

抱歉!评论已关闭.