詳解springmvc之json數(shù)據(jù)交互controller方法返回值為簡單類型
當(dāng)controller方法的返回值為簡單類型比如String時,該如何與json交互呢?
使用@RequestBody
比如代碼如下:
@RequestMapping(value="/ceshijson",produces="application/json;charset=UTF-8")
@ResponseBody
public String ceshijson(@RequestBody String channelId) throws IOException{
return channelId;
如果代碼為上面這種情況時,前臺發(fā)送json時,應(yīng)該這樣寫(寫法有很多,能用就行)
function channel(){
//先獲取選中的值
var channelId = $("#channelId option:selected").val();
//來判斷發(fā)送的鏈接
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);
}
});
}
}
這里需要特別注意:上篇也強(qiáng)調(diào)過,使用了@RequestBody時,它要求String channelId接收到數(shù)據(jù)為json字符串。也就是要是data寫成這樣: data:{‘channelId':channelId},就是錯誤的。因?yàn)檫@是json對象形式。
要是你不想使用JSON.stringify()這個函數(shù),那就自己手動字符串拼接:
data:'{"channelId":'+channelId+'}'
這里還要注意channelId是雙引號,不能寫成單引號,因?yàn)檫@是json語法規(guī)則。你改成單引號,也就是
**錯誤寫法
data:"{'channelId':"+channelId+"}"
這種形式,雖然可以傳給后臺,但是后臺傳回來的會出現(xiàn)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對象轉(zhuǎn)換為json字符串。
總結(jié):這種方式,其實(shí)是沒有多大的實(shí)際意思,因?yàn)橐话憬邮諗?shù)據(jù)不是這么接收的。只做了解!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Springboot項(xiàng)目長時間不進(jìn)行接口操作,提示HikariPool-1警告的解決
這篇文章主要介紹了Springboot項(xiàng)目長時間不進(jìn)行接口操作,提示HikariPool-1警告的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
基于SpringBoot+Avue實(shí)現(xiàn)短信通知功能
Avue是基于vue和element-ui的快速開發(fā)框架 ,它的核心是數(shù)據(jù)驅(qū)動UI的思想,讓我們從繁瑣的crud開發(fā)中解脫出來,本文將給大家介紹一下使用SpringBoot+Avue實(shí)現(xiàn)短信通知功能,文中有詳細(xì)的代碼示例,需要的朋友可以參考下2023-09-09
使用Feign遠(yuǎn)程調(diào)用時,序列化對象失敗的解決
這篇文章主要介紹了使用Feign遠(yuǎn)程調(diào)用時,序列化對象失敗的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
Spring使用RestTemplate和Junit單元測試的注意事項(xiàng)
這篇文章主要介紹了Spring使用RestTemplate和Junit單元測試的注意事項(xiàng),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10

