打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
使用@RequestBody 取POST方式的json字符串 ajax

关于@RequestBody 映射实体类的方法,网上大量讨论,不再细说。

但前端提交复杂结构,或动态性比较大的数据结构时,就可能不能映射固定类。用map方式貌似也不太灵(没有仔细研究,过程中,前端json结构比较复杂时,失败了)。

前端写法:

 var json_data={
              "name" : "demographics",
              "params" : [1 , 2, 3],
              "items" : [ {"name" : "中文", "value" : 10 },
                          {"name": "item2",  "value" : 20 }
                        ]
           };
        $.ajax({
        url : 'chart/graphics',
        type : 'post',
        data : JSON.stringify(json_data),
        contentType : 'application/json;charset=utf-8' 
  //中文需要加上charset=utf-8才正确
     });

后端写法

   @RequestMapping(value="/{name}", method=RequestMethod.POST, produces="application/json;charset=utf-8;")
    @ResponseBody
    public String postDashboardItem(
            @PathVariable(value="name")  String name,
            @RequestBody  String params,

             Model model) {

      JSONObject object= JSON.parseObject(params);

     //do somthings

     return "";  //json string

}

更正:

感谢alan_waker的提醒,重复做了map接收参数的实验,效果不错。

前端写法一样,

后端写法:

   @RequestMapping(value="/{name}", method=RequestMethod.POST, produces="application/json;charset=utf-8;")
    @ResponseBody
    public String postDashboardItem(
            @PathVariable(value="name")  String name,
            @RequestBody  Map<String, Object> params,

             Model model) {

     //do somthings

     return "";  //json string

}

需要引用 jackson-databind包,否则前端会报 415错误。后台报Content type 'application/json;charset=UTF-8' not supported。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
SpringBoot获取前端传递Json的几种方法
使用Java为Hangouts Chat API设置传入的webhook?
JQuery Ajax调用asp.net后台方法
如何设置Response中的ContentType
requests发送post请求的一些疑点
Post JSON data to RESTful datasnap server from delphi client [发布RESTful JSON数据从德尔福datasnap服务器端]
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服