详解springmvc之json数据交互controller方法返回值为简单类型
程序员文章站
2024-02-23 10:48:22
当controller方法的返回值为简单类型比如string时,该如何与json交互呢?
使用@requestbody
比如代码如下:
@requ...
当controller方法的返回值为简单类型比如string时,该如何与json交互呢?
使用@requestbody
比如代码如下:
@requestmapping(value="/ceshijson",produces="application/json;charset=utf-8") @responsebody public string ceshijson(@requestbody string channelid) throws ioexception{ return channelid;
如果代码为上面这种情况时,前台发送json时,应该这样写(写法有很多,能用就行)
function channel(){ //先获取选中的值 var channelid = $("#channelid option:selected").val(); //来判断发送的链接 if(channelid ==2){ $.ajax({ url:"ceshijson", type:"post", datatype:'json', contenttype:'application/json;charset=utf-8', data:json.stringify({'channelid':channelid}), success:function(data){ alert(data.channelid); }, error:function(xmlhttprequest, textstatus, errorthrown){ alert("error") alert(xmlhttprequest.status); alert(xmlhttprequest.readystate); alert(textstatus); } }); } }
这里需要特别注意:上篇也强调过,使用了@requestbody时,它要求string channelid接收到数据为json字符串。也就是要是data写成这样: data:{‘channelid':channelid},就是错误的。因为这是json对象形式。
要是你不想使用json.stringify()这个函数,那就自己手动字符串拼接:
data:'{"channelid":'+channelid+'}'
这里还要注意channelid是双引号,不能写成单引号,因为这是json语法规则。你改成单引号,也就是
**错误写法
data:"{'channelid':"+channelid+"}"
这种形式,虽然可以传给后台,但是后台传回来的会出现undefined。也就是key必须要用双引号包围。
不使用@requestbody
@requestmapping(value="/ceshijson",produces="application/json;charset=utf-8") @responsebody public string ceshijson(string channelid) throws ioexception{ map<string,object> map = new hashmap<string,object>(); map.put("channelid", channelid); objectmapper mapper = new objectmapper(); channelid = mapper.writevalueasstring(map); return channelid; }
前台代码
$.ajax({ url:"ceshijson", type:"post", datatype:'json', //contenttype:'application/json;charset=utf-8', data:"channelid="+channelid, success:function(data){ alert(data); }, error:function(xmlhttprequest, textstatus, errorthrown){ alert("error") alert(xmlhttprequest.status); alert(xmlhttprequest.readystate); alert(textstatus); } });
这种方式利用objectmapper中的writevalueasstring将java对象转换为json字符串。
总结:这种方式,其实是没有多大的实际意思,因为一般接收数据不是这么接收的。只做了解!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。