spring mvc@requestBody接收json对象字符串

本文详细介绍了如何在SpringMVC环境下正确使用@RequestBody注解来接收前端发送的JSON格式的数据。通过示例代码展示了如何配置JavaScript的Ajax请求以发送JSON数据,并在Java后端正确地解析这些数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以前,一直以为在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">  
/ **
 * 统一接口请求
 * @param {Object} apiName 接口名称如:user/login
 * @param {Object} data	请求参数对象
 * @param {Object} requestMethod 请求方式 如 :'post'
 * @param {Object} callback 回调方法
 */
var httpAjaxApi = function(apiName,requestData,requestMethod,callback){
    var userInfo = $.cookie("userInfo");
    var token;
    if(userInfo==null||userInfo=="null"){
    	token="";
    }else{
    	token = JSON.parse(userInfo).token;
    }
    $.ajax({
        type: requestMethod,
        dataType: 'json',
        url: '/DatacenterAPI/'+apiName,
        contentType: 'application/json',
        headers: {'token': token},
		data:JSON.stringify(requestData),
		timeout: 60000,
        success: function(data) {
        	if(data.errorCode!=0){
        		if(data.errorCode==2002){
        		/**
				 * token失效跳转登录页面
				 */
				top.window.location.href = "../../login.html";
        		}else{
        			alert(data.errorMsg);
        		}
        	}else{
        		/**
        		 * 业务处理成功回调
        		 */
        		callback(data);
        	}
        },
        error:function(data){
            alert("error");
        }
	});
	
}
</script> 

Datatables

ajax: {
    type:"post",
    url:"/DatacenterAPI/user/query",
       contentType: 'application/json',
       headers: {'token': token},
    data:function(data){
    let obj = {};//向后台传参数的
obj.name=$('#user_name').val();
obj.loginname=$('#login_name').val();
obj.orgId=$('#org_Id').val();
obj.page = (parseInt(data.start)/parseInt(data.length))+1;
obj.rows=data.length;
return JSON.stringify(obj);
    },
    dataSrc: function(json){
       /*ajax回调*/
return json.data.rows;
   }
   },


/**

* 查询所有机构信息
* @param dto
* @param token
* @return
*/
@ResponseBody
@RequestMapping(value="query", method=RequestMethod.POST)
public ResultBean querySyorg(@RequestBody OrgInfoDto dto,@RequestHeader(value="token") String token){
ResultBean res = new ResultBean();
Map<String,Object> param = FrameUtils.beanToMap(dto);
Page total = PageHelper.startPage(res.getPage(), res.getRows());
Map<String,Object> data=syorgService.query(param);
res.setData(data);
res.setRecordsFiltered(Long.valueOf(String.valueOf(data.get("recordsFiltered"))));
res.setRecordsTotal(Long.valueOf(String.valueOf(data.get("recordsTotal"))));
res.setTotal(Long.valueOf(String.valueOf(data.get("total"))));
res.setErrorCode(0);
res.setErrorMsg("查询机构成功");
res.setServiceName("org/query");
System.err.println(JSON.toJSONString(res));
return res;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值