2019-01-28 关于 前后台交互传值的问题

2019-01-28  本文已影响0人  vpike

@RequestBody应用

当时并不太了解@RequestBody,也并没有使用js提供的JSON.stringify()方法

所有都是自己写的,比如js将json转为字符串的方法,后台接收json转成实体的方法。

最近接触到了@RequestBody,于是想将之前的代码改写一下。

首先@RequestBody需要接的参数是一个string化的json,这里直接使用JSON.stringify(json)这个方法来转化

其次@RequestBody,从名称上来看也就是说要读取的数据在请求体里,所以要发post请求

第三,要设置contentType,contentType:"application/json,明确的告诉服务器发送的内容是json,而默认的contentType是application/x-www-form-urlencoded; charset=UTF-8

当接收参数的时候,用@RequestParam,并且

当不用@ RequestParam时候,必须保证和前端传递name名字相同,否则必须按照严格的格式写@RequestParam(value="path") String path1!!

表单序列化后 转json串

var DataDeal = {
        //将从form中通过$('#refer').serialize()获取的值转成json
        formToJson: function (data) {
            data=data.replace(/&/g,"\",\"");
            data=data.replace(/=/g,"\":\"");
            data="{\""+data+"\"}";
            return data;
        }
    };
    var dataCollect=$('#form').serialize();
                dataCollect= decodeURIComponent(dataCollect,true);//防止中文乱码
                var jsondata=DataDeal.formToJson(dataCollect);//转化为json
  1. 遇到个跨域调用,因为传个我的参数不定,所以需要通过来接收参数并进行签名验证等操作
    理所当然的写出了下面的代码,但是发现map里并没有获取到传来的key-value值
    @RequestMapping(value = "/callback", produces = "text/html;charset=UTF-8")  
    @ResponseBody  
    public String callback(@RequestBody Map<String, String> params) {  
        return null;  
    }  
    @RequestMapping(value = "/callback", produces = "text/html;charset=UTF-8")  
    @ResponseBody  
    public String callback(HttpServletRequest httpServletRequest) {  
        Map<String, String> params = httpServletRequest.getParameterMap();  
        return null;  
    }  

“用@RequestParam试试”,然后就对了。。对了。。了。。

@RequestMapping(value = "/callback", produces = "text/html;charset=UTF-8")  
@ResponseBody  
public String callback(@RequestParam Map<String, String> params) {  
    return null;  
}

2.以前,一直以为在SpringMVC环境中,@RequestBody接收的是一个Json对象,一直在调试代码都没有成功,后来发现,其实 @RequestBody接收的是一个Json对象的字符串,而不是一个Json对象。然而在ajax请求往往传的都是Json对象,后来发现用 JSON.stringify(data)的方式就能将对象变成字符串。同时ajax请求的时候也要指定dataType: "json",contentType:"application/json" 这样就可以轻易的将一个对象或者List传到Java端,使用@RequestBody即可绑定对象或者List.

<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>
  @RequestMapping(value = "saveUser", method = {RequestMethod.POST }}) 
    @ResponseBody  
    public void saveUser(@RequestBody List<User> users) { 
         userService.batchSave(users); 
    } 
上一篇下一篇

猜你喜欢

热点阅读