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