美文网首页
2019-01-28 关于 前后台交互传值的问题

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

作者: vpike | 来源:发表于2019-01-28 14:57 被阅读0次

    @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;  
        }  
    
    • 之后我发现HttpServletRequest有一个getParameterMap方法好像很牛逼的样子
        @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试试”,然后就对了。。对了。。了。。

    @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.

    • JavaScript 代码:
    <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代码
      @RequestMapping(value = "saveUser", method = {RequestMethod.POST }}) 
        @ResponseBody  
        public void saveUser(@RequestBody List<User> users) { 
             userService.batchSave(users); 
        } 
    

    相关文章

      网友评论

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

          本文链接:https://www.haomeiwen.com/subject/douajqtx.html