快速解决SpringMVC @RequestBody 用map接收请求参数的问题

时间:2022-09-27 14:08:31

一:遇到个跨域调用,因为传个我的参数不定,所以需要通过map来接收参数并进行签名验证等操作

理所当然的写出了下面的代码,但是发现map里并没有获取到传来的key-value值

?
1
2
3
4
5
@requestmapping(value = "/callback", produces = "text/html;charset=utf-8")
@responsebody
public string callback(@requestbody map<string, string> params) {
 return null;
}

之后我发现httpservletrequest有一个getparametermap方法好像很牛逼的样子

?
1
2
3
4
5
6
@requestmapping(value = "/callback", produces = "text/html;charset=utf-8")
@responsebody
public string callback(httpservletrequest httpservletrequest) {
 map<string, string> params = httpservletrequest.getparametermap();
 return null;
}

然而这么写还是不对,因为这个方法其实是返回的一个map<string, string[]>对象,而不是我想象中的简单的map<string, string>类型,这里是可以获得正确的参数的,但是需要手动进行转换,不可能是这种情况呀,一定有更好的解决办法 “用@requestparam试试”,然后就对了。。对了。。了。。

?
1
2
3
4
5
@requestmapping(value = "/callback", produces = "text/html;charset=utf-8")
@responsebody
public string callback(@requestparam map<string, string> params) {
 return null;
}

二:以前,一直以为在springmvc环境中,@requestbody接收的是一个json对象,一直在调试代码都没有成功,后来发现,其实 @requestbody接收的是一个json对象的字符串,而不是一个json对象。然而在ajax请求往往传的都是json对象,后来发现用 json.stringify(data)的方式就能将对象变成字符串。

同时ajax请求的时候也要指定datatype: "json",contenttype:"application/json" 这样就可以轻易的将一个对象或者list传到java端,使用@requestbody即可绑定对象或者list.

javascript 代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<script type="text/javascript">
 $(document).ready(function(){
 var savedataary=[];
 var data1={"username":"test","address":"gz"};
 var data2={"username":"ququ","address":"gr"};
 savedataary.push(data1);
 savedataary.push(data2); 
 $.ajax({
  type:"post",
  url:"user/saveuser",
  datatype:"json",
  contenttype:"application/json"
  data:json.stringify(savedata),
  success:function(data){
     
  }
  });
 });
</script>

java代码

?
1
2
3
4
5
@requestmapping(value = "saveuser", method = {requestmethod.post }})
@responsebody
public void saveuser(@requestbody list<user> users) {
 userservice.batchsave(users);
 }

以上这篇快速解决springmvc @requestbody 用map接收请求参数的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/xiaowu2017/article/details/56830866