声明:
GET和POST方式我将所有我能想到的组合都进行了一边测试,发现GET只能传递不含有List<自定义类型>的JSON数据
POST没有限制。
前端:
<script type="text/javascript">
var json={username:"zangsan",password:"123456",favs:["football","running"]}
console.log(encodeURI((JSON.stringify(json))));
$.ajax({
url: 'test1',
type: "GET",
traditional:true,
data: json,
success: function (data) {
},contentType: "application/json;charset=UTF-8"
});
json={username:"zangsan",password:"123456",favs:["football","running"],friends:[{name:"ho",age:10},{name:"zz",age:12}]}
$.ajax({
url: 'test2',
type: "POST",
data: JSON.stringify(json),
success: function (data) {
},
contentType: "application/json;charset=UTF-8"
});
</script>
注意点:
1)GET 请求发送的并不是JSON字符串,jquery会给他转成url的请求参数
2)traditonal:true 不能省,这是防止浏览器将集合参数名为"favs[]"这样后台会报错
3)POST请求的JSON.stringify不能省略
4)至于contentType大家都说不能省,但是我发现还是可以省略的(chrome浏览器测试的)
java后台
/**
* GET 获取请求,注意这里获取的并不是json,就是普通的参数
* @param users
*/
@GetMapping("/test1")
@ResponseBody
public void test1( User user){
System.out.println(user.getUsername());
System.out.println(user.getFavs());
System.out.println(user.getFriends());
}
/**
* post 返送来的JSON字符串处理
* @param users
*/
@PostMapping("/test2")
@ResponseBody
public void test2(@RequestBody User user){
System.out.println(user.getUsername());
System.out.println(user.getFavs());
System.out.println(user.getFriends());
}
public class Friends {
public String name;
public Integer age;
}
public class User {
public String username;
public String password;
private List<String> favs;
private List<Friends> friends;
}
注意点:
1)GET按照普通参数获取方式获取,这里并没有什么注解需要注意,但有一点@ResponseBody不能省,这是ajax请求处理必须要做的事情,而@RequestBody不要加,加了会抛异常
2)POST这里@RequestBody必加
我想这里变的问题无非就是要搞清楚jquery的ajax方式传递ajax请求数据的格式
再就是研究一下SpringMVC的获取ajax请求参数处理上的问题,想要搞清除,就得看源码。以后有时间在做。