婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > jQuery調(diào)用WebService返回JSON數(shù)據(jù)及參數(shù)設(shè)置注意問題

jQuery調(diào)用WebService返回JSON數(shù)據(jù)及參數(shù)設(shè)置注意問題

熱門標(biāo)簽:申請400電話手續(xù) 南陽外呼系統(tǒng)定制化 百度ai地圖標(biāo)注 同安公安400電話怎么申請流程 玉林市機(jī)器人外呼系統(tǒng)哪家好 合肥電銷外呼系統(tǒng)哪家公司做的好 蘋果手機(jī)凱立德地圖標(biāo)注 電話機(jī)器人軟件銷售工作 預(yù)測式外呼系統(tǒng)使用說明
.NET Framework 3.5的發(fā)布解決了WebService調(diào)用中json問題,本文將介紹jQuery調(diào)用基于.NET Framework 3.5的WebService返回JSON數(shù)據(jù),另外還要介紹一下用jQuery調(diào)用WebService的參數(shù)設(shè)置及設(shè)置不當(dāng)所出現(xiàn)的問題,還有出現(xiàn)問題的原因

jQuery調(diào)用WebService網(wǎng)上的介紹也比較多,最近的項目中我也用到不少,一直都很少用.NET Ajax,比較鐘情于jQuery調(diào)用請求WebService有幾種方法,這主要說一下POST與GET方法,其實安全方法考慮不建議使用GET方法,下面就說一下用jquery調(diào)用WebService的參數(shù)設(shè)置及設(shè)置不當(dāng)所出現(xiàn)的問題,還有出現(xiàn)問題的原因。我們這里只討論返回JSON數(shù)據(jù)的情況,相信大家都比較了解JSON格式的數(shù)據(jù)對于ajax的方便,不了解的可以從網(wǎng)上找一下這方面的資料來看一下,這里就不多說了,或者我以后再寫一篇這方面的文章。

下面是jQuery調(diào)用WebService服務(wù)器端代碼

WS1和WS2方法為POST方法請求的方法,所以設(shè)置UseHttpGet 為false,WS3與WS4為GET方法請求的方法,設(shè)置UseHttpGet 為true。

復(fù)制代碼 代碼如下:

using System.Web.Script.Services;
using System.Web.Services;
namespace WebService35
{
///
/// WebService1 的摘要說明
///
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
// 若要允許使用 ASP.NET AJAX 從腳本中調(diào)用此 Web 服務(wù),請取消對下行的注釋。
[System.Web.Script.Services.ScriptService]
public class WebService1 : System.Web.Services.WebService
{
[WebMethod]
[ScriptMethod(UseHttpGet = false)]
public string WS1()
{
return "POST無參數(shù)";
}
[WebMethod]
[ScriptMethod(UseHttpGet = false)]
public string WS2(string s)
{
return s;
}
[WebMethod]
[ScriptMethod(UseHttpGet = true)]
public string WS3()
{
return "GET無參數(shù)";
}
[WebMethod]
[ScriptMethod(UseHttpGet = true)]
public string WS4(string s)
{
return s;
}
}
}


復(fù)制代碼 代碼如下:

function fun1() {
$.ajax({
url: "WebService1.asmx/WS1",
type: "POST",
dataType: "json",
contentType: "application/json; charset=utf-8",
data: "",
success: function(json) {
alert(json.d);
},
error: function(x, e) {
alert(x.responseText);
},
complete: function(x) {
alert(x.responseText);
}
});
}


上面的JS方法為用POST方法請求無參數(shù)的WebService方法的代碼,不過以上代碼并不能返回正確的JSON格式的數(shù)據(jù),而是返回XML格式的數(shù)據(jù),回為要使WebService返回JSON格式的數(shù)據(jù),要在Request Headers中設(shè)置Content-Type為application/json,有人要問了,你不設(shè)置了contentType為 “application/json; charset=utf-8”了嗎?沒錯,是設(shè)置了,不過在jquery中,如果Content-Length為0或者沒有設(shè)置,它會忽略你設(shè)置的 contentType的,我可以看下面的這個圖,這是抓取的Request Headers的數(shù)據(jù),可以看到Content-Length為0,并且沒有Content-Type,所WebService就不知道我們需要JSON 格式的數(shù)據(jù),它就返回了默認(rèn)的XML格式的數(shù)據(jù)給我們,之所以為0,是因為我沒有提交任何數(shù)據(jù)。

這要怎么辦呢?繼續(xù)看下面的JS代碼,因為我們這里是調(diào)用的一個沒能參數(shù)的WebService方法,所以我們可以提交一個空和JSON對象“{}",如下所示,設(shè)置data為{}。

復(fù)制代碼 代碼如下:

function fun1() {
$.ajax({
url: "WebService1.asmx/WS1",
type: "POST",
dataType: "json",
contentType: "application/json; charset=utf-8",
data: "{}",
success: function(json) {
alert(json.d);
},
error: function(x, e) {
alert(x.responseText);
},
complete: function(x) {
alert(x.responseText);
}
});
}

現(xiàn)在我再來看下圖,可以看到,Content-Length已經(jīng)為2了,并且也有Contetn-Type,還是我們設(shè)置的值,這樣就能正確的返回JSON數(shù)據(jù)給我們使用了。

還有一種方法就是:既然jquery不給我們設(shè)置Content-Type,我們可以自己設(shè)置,如下面的代碼所示,我們在發(fā)送數(shù)據(jù)之前設(shè)置一下Content-Type為“application/json; charset=utf-8”,這樣就可以了。

復(fù)制代碼 代碼如下:

function fun1() {
$.ajax({
url: "WebService1.asmx/WS1",
type: "POST",
dataType: "json",
data: "",
beforeSend: function(x) {
x.setRequestHeader("Content-Type", "application/json; charset=utf-8");
},
success: function(json) {
alert(json.d);
},
error: function(x, e) {
alert(x.responseText);
},
complete: function(x) {
alert(x.responseText);
}
});
}

下面是我們手工設(shè)置了Content-Type之后抓取的Request Headers,可以看到,即使Content-Length為0,里面也有了正確的Content-Type了。

不過,需要注意的是:如果我們設(shè)置了jquery的contentType,又發(fā)送了一個空的JSON對象,并且還手工設(shè)置了Content-Type,就如下代碼所示:

復(fù)制代碼 代碼如下:

function fun1() {
$.ajax({
url: "WebService1.asmx/WS1",
type: "POST",
dataType: "json",
contentType: "application/json; charset=utf-8",
data: "{}",
beforeSend: function(x) {
x.setRequestHeader("Content-Type", "application/json; charset=utf-8");
},
success: function(json) {
alert(json.d);
},
error: function(x, e) {
alert(x.responseText);
},
complete: function(x) {
alert(x.responseText);
}
});
}

那么在IE發(fā)送的Requst Headers就如下圖所示,你會看到Content-Type有兩個用逗號隔開的值,這是為什么呢?因為,jquery為Content-Type設(shè)置了一次值,我們手工又設(shè)置一次,而在IE是多次設(shè)置Content-Type的值它會追加,而不是替換,不過這并不影響WebService正確返回 JSON數(shù)據(jù)給我們,不過應(yīng)該避免這種情況出現(xiàn)。

如果說上面那種設(shè)置兩次Content-Type的值還能正確的返回JSON數(shù)據(jù),那么下面代碼就不能正確返回JSON數(shù)據(jù)了。

復(fù)制代碼 代碼如下:

function fun1() {
$.ajax({
url: "WebService1.asmx/WS1",
type: "POST",
dataType: "json",
data: "{}",
beforeSend: function(x) {
x.setRequestHeader("Content-Type", "application/json; charset=utf-8");
},
success: function(json) {
alert(json.d);
},
error: function(x, e) {
alert(x.responseText);
},
complete: function(x) {
alert(x.responseText);
}
});
}

從下圖可以看到Content-Type也有兩個值,不過這個和上面那個還有點不一樣,這次呢這個值是不一樣的,一個是 application/x-www-form-urlencoded,一個是application/json; charset=utf-8,這種情況就不能正確的返回JSON格式的數(shù)據(jù)了。這又是為什么呢?這是因為我們沒有為jquery設(shè)置 contentType為,并且又提交了一個空的JSON對象,可以為什么這樣就會使用Content-Type出現(xiàn)這樣的情況的呢?因為jquery的 ajax用POST方法提交數(shù)據(jù)的時候,如果沒有設(shè)置contentType,并且所發(fā)送的數(shù)據(jù)不為空,那么它就會為ContentType設(shè)置一個默認(rèn)值,也就是application/x-www-form-urlencoded,所以就會出現(xiàn)這種情況了。

所以呢,在用POST方法請求的時候,如果有提交數(shù)據(jù),也就是jquery ajax的datar屬性不空的情況下(不為空的情況:1.發(fā)送一個空對象調(diào)用無參數(shù)的WebService方法;2.請一個有參數(shù)的 WebService方法。),一定要設(shè)置contentType屬性,并且不能手工設(shè)置Content-Type了。

下面是請求有參數(shù)的WebService方法,一些情況在上面也都說過了,這里就不多說了。

不過有一點要注意,就是用POST方法請求的時候,不用手工去編碼有漢字的參數(shù)值,如下面的data: "{s:'POST有參數(shù)'}",就不用寫成data: "{s:"+encodeURI('POST有參數(shù)')+"}"了。

復(fù)制代碼 代碼如下:

function fun2() {
$.ajax({
url: "WebService1.asmx/WS2",
contentType: "application/json; charset=utf-8",
type: "POST",
dataType: "json",
data: "{s:'POST有參數(shù)'}",
success: function(json) {
alert(json.d);
},
error: function(x, e) {
alert(x.responseText); ;
},
complete: function(x) {
alert(x.responseText);
}
});
}

以上是我們說的用POST方法請求,下面是用GET方法請求。

下面是一個用GET方法請求一個無參數(shù)的WebService方法,不過這是一段錯誤的代碼,錯在哪兒呢,各們童鞋可以自己想一下,我們下面一起說。

復(fù)制代碼 代碼如下:

function fun3() {
$.ajax({
url: "WebService1.asmx/WS3",
type: "GET",
dataType: "json",
data: "",
contentType: "application/json; charset=utf-8",
success: function(json) {
alert(json.d);
},
error: function(x, e) {
alert(x.responseText);
},
complete: function(x) {
alert(x.responseText);
}
});
}

下圖是用上面一段代碼請求所抓取的Request Headers,大家看一下,問題出在哪里。

下面的代碼是正確的用GET方法調(diào)用無參數(shù)的WebService方法。

復(fù)制代碼 代碼如下:

function fun3() {
$.ajax({
url: "WebService1.asmx/WS3",
dataType: "json",
data: "",
beforeSend: function(x) {
x.setRequestHeader("Content-Type", "application/json; charset=utf-8");
},
success: function(json) {
alert(json.d);
},
error: function(x, e) {
alert(x.responseText);
},
complete: function(x) {
alert(x.responseText);
}
});
}

下面的代碼是正確的用GET方法調(diào)用有參數(shù)的WebService方法。
復(fù)制代碼 代碼如下:

function fun4() {
$.ajax({
url: "WebService1.asmx/WS4",
dataType: "json",
data: encodeURI("s='GET有參數(shù)'"),
beforeSend: function(x) {
x.setRequestHeader("Content-Type", "application/json; charset=utf-8");
},
success: function(json) {
alert(json.d);
},
error: function(x, e) {
alert(x.responseText);
},
complete: function(x) {
alert(x.responseText);
}
});
}

下圖是正確的用GET方法(有參數(shù)和無參數(shù))調(diào)用WebService方法所抓取的Request Headers。

從上圖可以看到,用GET方法請求,不管是有參數(shù)還是無參數(shù),都是沒有Content-Length的,所以jquery也就不能為我們設(shè)置 Content-Type了,我只能手工設(shè)置Content-Type,所以我們也就沒有必要設(shè)置jquery ajax的contentType了。

需要注意的是,GET方法與POST方法不同,有參數(shù)的時候,如果參數(shù)的值不是ASCII字符,要用encodeURI編一下碼,要不服務(wù)端接收到的數(shù)據(jù)為亂碼。

您可能感興趣的文章:
  • 淺談對Jquery+JSON+WebService的使用小結(jié)
  • 排除JQuery通過HttpGet調(diào)用WebService返回Json時“parserror”錯誤
  • jQuery結(jié)合Json提交數(shù)據(jù)到Webservice,并接收從Webservice返回的Json數(shù)據(jù)
  • asp.net下使用jquery 的ajax+WebService+json 實現(xiàn)無刷新取后臺值的實現(xiàn)代碼
  • 用Jquery訪問WebService并返回Json的代碼
  • jQuery調(diào)用Webservice傳遞json數(shù)組的方法

標(biāo)簽:臺州 南昌 揚州 南京 嘉興 淄博 南京 海南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《jQuery調(diào)用WebService返回JSON數(shù)據(jù)及參數(shù)設(shè)置注意問題》,本文關(guān)鍵詞  jQuery,調(diào)用,WebService,返回,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《jQuery調(diào)用WebService返回JSON數(shù)據(jù)及參數(shù)設(shè)置注意問題》相關(guān)的同類信息!
  • 本頁收集關(guān)于jQuery調(diào)用WebService返回JSON數(shù)據(jù)及參數(shù)設(shè)置注意問題的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91黄色免费看| 色综合久久天天| 一本久道久久综合中文字幕| 五月婷婷另类国产| 懂色av一区二区三区免费看| 欧美大片拔萝卜| 亚洲第一精品在线| 一区二区欧美视频| 色狠狠av一区二区三区| 亚洲精品国产无套在线观| 不卡欧美aaaaa| 1区2区3区国产精品| 成人爽a毛片一区二区免费| 久久色在线视频| 91亚洲永久精品| 亚洲精品水蜜桃| 精品盗摄一区二区三区| 午夜精品福利一区二区三区av| 欧美最新大片在线看| 亚洲一级二级在线| 欧美精品v国产精品v日韩精品| 婷婷六月综合亚洲| 久久精品一区二区三区四区| 国产精品亚洲а∨天堂免在线| 久久精品亚洲乱码伦伦中文| 成人高清视频在线| 亚洲精品五月天| 日韩精品专区在线| 色婷婷久久一区二区三区麻豆| 首页亚洲欧美制服丝腿| 国产日韩欧美一区二区三区乱码 | 成人天堂资源www在线| 亚洲你懂的在线视频| 欧美久久一二区| 日韩福利电影在线观看| 中文字幕日韩av资源站| 51精品国自产在线| 国产91富婆露脸刺激对白| 五月婷婷欧美视频| 久久亚洲精精品中文字幕早川悠里| gogo大胆日本视频一区| 亚洲va国产天堂va久久en| 中文字幕精品在线不卡| 欧美伊人久久久久久午夜久久久久| 久久se精品一区精品二区| 亚洲综合在线视频| 精品日韩欧美在线| 成人永久aaa| 亚洲欧美视频在线观看视频| 奇米精品一区二区三区在线观看一| 欧美一区二区精美| 久久综合九色综合97婷婷女人| 久久国产婷婷国产香蕉| 欧美一级淫片007| 五月天网站亚洲| 不卡视频一二三| 欧美电视剧免费观看| 亚洲国产精品麻豆| 91免费看片在线观看| 国产欧美日韩麻豆91| 国产精品一区一区三区| 久久国产成人午夜av影院| 欧美综合色免费| 亚洲成年人网站在线观看| 欧亚洲嫩模精品一区三区| 亚洲一二三区视频在线观看| 欧美日韩一级视频| 午夜a成v人精品| 日韩欧美中文字幕公布| 美女久久久精品| 精品国产乱码久久久久久免费| 美腿丝袜一区二区三区| 国产一区二区日韩精品| 在线看日本不卡| 欧洲亚洲国产日韩| 日本特黄久久久高潮| 欧美大胆人体bbbb| 国产一区二区三区av电影| 亚洲国产成人午夜在线一区 | 免费在线观看日韩欧美| 欧洲生活片亚洲生活在线观看| 亚洲一区二区美女| 日韩午夜激情av| 成人免费视频视频| 亚洲一区二区三区中文字幕在线| 蜜桃久久久久久| 欧美一区二区三区在线看| 91精品国产欧美一区二区18| 国产一区二区网址| 亚洲精选一二三| 91精品久久久久久蜜臀| 国产福利一区在线观看| 1000精品久久久久久久久| 91精品综合久久久久久| av电影在线观看一区| 日韩精品电影在线观看| 久久亚洲综合av| 欧美另类久久久品| 成人免费看的视频| 欧美a一区二区| 日韩视频在线一区二区| 国产精品三级在线观看| 欧美片网站yy| 成人精品高清在线| 蜜乳av一区二区| 樱花草国产18久久久久| 欧美一区二区三区爱爱| 99国产精品久久久久久久久久久| 午夜天堂影视香蕉久久| 国产欧美久久久精品影院| 在线观看91视频| 日韩 欧美一区二区三区| 国产精品精品国产色婷婷| 91精品视频网| 亚洲bt欧美bt精品777| 欧美剧在线免费观看网站| 午夜欧美大尺度福利影院在线看| 久久久久久一级片| 91精品国产91久久综合桃花| 久久精品av麻豆的观看方式| 欧美日韩在线直播| 亚洲一二三四久久| 成人成人成人在线视频| 理论片日本一区| 亚洲v中文字幕| 亚洲色图在线视频| 久久久久亚洲综合| 日韩美女一区二区三区| 666欧美在线视频| 欧美三级视频在线播放| 岛国精品在线观看| 国产成人三级在线观看| 国产电影精品久久禁18| 亚洲色图色小说| 欧美肥胖老妇做爰| 日韩免费一区二区三区在线播放| 欧美亚洲国产bt| 欧美日韩免费一区二区三区| 不卡高清视频专区| av福利精品导航| 亚洲精品久久久久久国产精华液| 国产精品久久久久aaaa樱花| 国产精品久久久久久久久果冻传媒| 中文字幕亚洲一区二区av在线 | 日本不卡的三区四区五区| 亚洲国产一二三| 午夜成人免费电影| 洋洋av久久久久久久一区| 欧美美女视频在线观看| 欧美视频一二三区| 国内精品嫩模私拍在线| 国产精品久久久久aaaa樱花 | 99国产麻豆精品| 成人午夜大片免费观看| 丁香激情综合国产| av色综合久久天堂av综合| 在线视频一区二区三区| 欧美精三区欧美精三区| 91蜜桃免费观看视频| 亚洲成人免费视| 久草这里只有精品视频| 丁香婷婷深情五月亚洲| 欧美性受xxxx黑人xyx| 国产一区二区三区av电影| 亚洲成人综合在线| 久久成人av少妇免费| eeuss鲁片一区二区三区| 美女在线视频一区| 亚洲欧美在线另类| 日韩精品欧美成人高清一区二区| 国产精品自在在线| 亚洲激情第一区| 中文字幕亚洲不卡| 欧美一级高清片| 717成人午夜免费福利电影| 日韩欧美国产成人一区二区| 国产精品久久三区| 欧美a级一区二区| ●精品国产综合乱码久久久久| 婷婷激情综合网| 99国产欧美另类久久久精品 | 国产精品国产三级国产三级人妇 | 亚洲成a天堂v人片| 国产麻豆日韩欧美久久| 大桥未久av一区二区三区中文| 欧美日韩午夜在线| 亚洲丝袜另类动漫二区| 国产在线不卡一卡二卡三卡四卡| 国产91综合一区在线观看| 亚洲精品亚洲人成人网| 日韩三级在线免费观看| 亚洲123区在线观看| av电影天堂一区二区在线观看| 欧美va亚洲va在线观看蝴蝶网| 亚洲精品美腿丝袜| 色噜噜久久综合| 亚洲人成伊人成综合网小说| 国产a精品视频| 欧美mv和日韩mv的网站| 亚洲免费观看高清|