成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > jQuery調用WebService返回JSON數據及參數設置注意問題

jQuery調用WebService返回JSON數據及參數設置注意問題

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

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

下面是jQuery調用WebService服務器端代碼

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

復制代碼 代碼如下:

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 從腳本中調用此 Web 服務,請取消對下行的注釋。
[System.Web.Script.Services.ScriptService]
public class WebService1 : System.Web.Services.WebService
{
[WebMethod]
[ScriptMethod(UseHttpGet = false)]
public string WS1()
{
return "POST無參數";
}
[WebMethod]
[ScriptMethod(UseHttpGet = false)]
public string WS2(string s)
{
return s;
}
[WebMethod]
[ScriptMethod(UseHttpGet = true)]
public string WS3()
{
return "GET無參數";
}
[WebMethod]
[ScriptMethod(UseHttpGet = true)]
public string WS4(string s)
{
return s;
}
}
}


復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

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);
}
});
}

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

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

復制代碼 代碼如下:

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之后抓取的Request Headers,可以看到,即使Content-Length為0,里面也有了正確的Content-Type了。

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

復制代碼 代碼如下:

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設置了一次值,我們手工又設置一次,而在IE是多次設置Content-Type的值它會追加,而不是替換,不過這并不影響WebService正確返回 JSON數據給我們,不過應該避免這種情況出現。

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

復制代碼 代碼如下:

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格式的數據了。這又是為什么呢?這是因為我們沒有為jquery設置 contentType為,并且又提交了一個空的JSON對象,可以為什么這樣就會使用Content-Type出現這樣的情況的呢?因為jquery的 ajax用POST方法提交數據的時候,如果沒有設置contentType,并且所發(fā)送的數據不為空,那么它就會為ContentType設置一個默認值,也就是application/x-www-form-urlencoded,所以就會出現這種情況了。

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

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

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

復制代碼 代碼如下:

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

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

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

復制代碼 代碼如下:

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方法調用無參數的WebService方法。

復制代碼 代碼如下:

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方法調用有參數的WebService方法。
復制代碼 代碼如下:

function fun4() {
$.ajax({
url: "WebService1.asmx/WS4",
dataType: "json",
data: encodeURI("s='GET有參數'"),
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方法(有參數和無參數)調用WebService方法所抓取的Request Headers。

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

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

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

標簽:臺州 南昌 揚州 南京 嘉興 淄博 南京 海南

巨人網絡通訊聲明:本文標題《jQuery調用WebService返回JSON數據及參數設置注意問題》,本文關鍵詞  jQuery,調用,WebService,返回,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《jQuery調用WebService返回JSON數據及參數設置注意問題》相關的同類信息!
  • 本頁收集關于jQuery調用WebService返回JSON數據及參數設置注意問題的相關信息資訊供網民參考!
  • 推薦文章
    国产精品18久久久久久首页狼| 免费毛片在线| av中文字幕不卡| 精品国产乱码久久久久久丨区2区| 亚洲欧美综合色| 亚洲天堂av一区二区三区| 色噜噜狠狠狠综合曰曰曰| 宅男午夜电影| 国产在线视频福利| 最新欧美日韩亚洲| 国产一区av在线| 欧美久久一区二区三区| 国产精品99视频| 国产尤物99| 懂色av蜜臀av粉嫩av分享吧| 免费黄色小视频在线观看| 免费国产黄色片| 你懂的一区二区| 国产精品一区免费视频| 国产精品偷伦视频免费观看了| 国产精品美女www| 91精品国产视频| 人妻精品久久久久中文字幕69| 成年人三级黄色片| 久久久久亚洲av成人无码电影| 色哟哟国产精品色哟哟| 奇米影视7777精品一区二区| 天天色天天操综合| 欧美高清无遮挡| 青草青草久热精品视频在线观看| 比比资源先锋影音网| 久久视频免费看| 欧美香蕉视频| 日本一区免费观看| 日韩国产高清影视| 欧美日韩视频在线播放| 国产精品毛片aⅴ一区二区三区| 欧美三级午夜理伦三级在线观看| 91精品国产99久久久久久| 在线看黄色的网站| 久久精品亚洲无码| 日本天堂在线播放| 欧美精品久久久久性色| 麻豆成人在线看| 国产又黄又大又粗的视频| 麻豆传媒在线播放| h版电影在线播放视频网址| 精品国产一区二区三区久久久蜜月| 久久www人成免费看片中文| 成人性视频免费看| 日韩国产精品一区二区三区| 欧美视频一二区| 国产成人久久婷婷精品流白浆| 成人免费在线观看| 亚洲日本香蕉视频| 日本少妇高清视频| jizz老师| 亚洲精品一区二区三区不| 色网在线播放| 国产精品伦一区二区| 激情欧美一区| 欧美日韩成人综合在线一区二区| 亚洲国产中文字幕在线| www.日韩| 亚洲人xxxx| 精品无码免费视频| 久草在线视频网站| 蜜桃传媒麻豆第一区在线观看| www.一区二区三区.com| 日本55丰满熟妇厨房伦| 欧美精品一区二区三区视频| 暴力调教一区二区三区| 四虎永久免费观看| 久久久久久久久毛片| 日本免费久久高清视频| 国产精品一区一区三区| 快she精品国产999| 欧美tk—视频vk| 国产精品亚洲第一区| 97视频在线观看亚洲| 欧美激情视频一区二区三区免费| 亚洲成人一二三| 日韩理论电影大全| 91精品办公室少妇高潮对白| 成人爽a毛片一区二区| 丰满大乳国产精品| 日韩电影在线免费看| 久久久久久国产免费a片| av漫画网站| blacked蜜桃精品一区| 日韩欧美精品| 视频欧美精品| 日本一区二区中文字幕| 国产精品永久| 日韩午夜小视频| 欧美日韩亚洲第一页| 欧美精品日韩| 在线看黄色的网站| 日本大胆在线观看| av色综合久久天堂av综合| 亚洲欧美日韩中文字幕在线观看| 国产老熟妇精品观看| 精品国产亚洲一区二区三区在线| 中文字幕超清在线免费观看| 国产一级免费av| 欧美日韩一区小说| 在线成人av电影| 一本一本久久a久久| 亚洲精品视频在线观看视频| 亚洲精品成a人ⅴ香蕉片| 亚洲精品91天天久久人人| 亚洲国产女人aaa毛片在线| 久久久久久久亚洲精品| 91在线看www| 成人自拍视频| 黄色av免费在线| 伊人激情综合| 另类中文字幕国产精品| 美女脱光内衣内裤| 中国极品少妇videossexhd| 久久天堂av综合合色蜜桃网| 日本在线视频中文有码| 日韩电影网址| 五月激情综合网| 97久久精品| 久久爱.com| 国产精品视频免费观看www| 国产精品日韩一区二区| 午夜影院免费版| 亚洲欧美成人一区二区三区| free亚洲| 欧美乱大交做爰xxxⅹ性3| 国产极品模特精品一二| japanese在线| 成a人片在线观看www视频| 免费xxxxx网站中文字幕| 九九热视频免费在线观看| 91啦中文在线观看| av动漫在线播放| 亚洲国产一区二区三区四区| 天海翼中文字幕| 日韩中文在线字幕| 国产婷婷色一区二区在线观看| 欧美日韩视频| 午夜精彩视频| 免费在线观看黄色小视频| 色综合久久悠悠| 无遮挡又色又刺激的女人视频| 国产精品vip| 9999热视频在线观看| 十大免费污污软件| 台湾无码一区二区| 私密视频在线观看| 污污视频网站在线免费观看| 国产精品欧美一区二区| 人与牲动交xxxbbb| 青草视频.com| 无码精品一区二区三区在线播放| 久久精品99无色码中文字幕| 熟妇人妻无乱码中文字幕真矢织江| 亚洲精品国产系列| 99久久99久久精品免费观看| 午夜久久久影院| 欧美激情综合色| 性刺激综合网| 国产亚洲日本欧美韩国| 国产成人免费在线视频| 日韩欧美电影一二三| 久久99精品久久久久久青青91| 三级亚洲高清视频| 人妻精品一区一区三区蜜桃91| 欧美精品精品精品精品免费| 在线看国产精品| 国产免费一级| 无尽裸体动漫2d在线观看| 国产+高潮+白浆+无码| 中国人xxxxx69免费视频| 国产精品久久久久久久天堂| 欧美午夜宅男影院在线观看| 久久精品免费观看| 久热国产精品视频一区二区三区| 国产成人亚洲精品| 国产精品毛片| 女人让男人操自己视频在线观看| 精品国产视频在线| 亚洲精品中文在线观看| 亚洲永久精品唐人导航网址| 日韩专区第一页| 91污片在线观看| 夜夜嗨av一区二区三区四区| 成人午夜激情视频| 国产麻豆免费视频| 96国产粉嫩美女| 手机在线观看日韩av| 黄视频在线观看网站| 加勒比免费视频| 爱爱爱爱免费视频| 国产三级精品三级在线观看| 青青视频在线播放| 亚洲免费影视第一页| 一区二区三区精品视频| 欧美区一区二区三区| 50路60路老熟妇啪啪| 男人天堂99| 日本羞羞视频| 久久精品盗摄| 国产日韩欧美中文在线| 欧美最猛性xxxx| 欧美日韩精品系列| 国产成人av一区| 大型av综合网站| 成人免费看吃奶视频网站| www.91popny.com| 97精品久久久| 羞羞网站在线看| 亚洲精品v欧美精品v日韩精品| 亚洲精品免费网站| 91免费精品国偷自产在线| 精品一区二区91| 欧美一级视频免费观看| 亚洲三级免费电影| 久久人体视频| 欧美在线视频精品| 欧美凹凸一区二区三区视频| 精品视频在线免费观看| 欧美国产日本高清在线| 日韩国产亚洲欧美| 久久综合综合久久| 菠萝菠萝蜜网站| 欧美网站免费| 精品美女在线观看视频在线观看| 99久久99| 欧美高清视频一区二区| 亚洲精品乱码久久久久| 西西444www无码大胆| 激情欧美成人久久综合小说| 久久一夜天堂av一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅| 九九热r在线视频精品| 久久久久久久激情视频| 黄在线观看在线播放720p| 中文字幕一区二区三区在线播放| 日韩在线视频观看免费| 成人免费黄色在线| av成人影院在线| 国产v片在线观看| 91麻豆国产精品久久| 99视频精品全部免费看| 无码精品国产一区二区三区免费| www.国产在线播放| 日韩一区精品| 亚洲专区在线播放| 久久午夜免费视频| 在线观看免费网站黄| 日本在线不卡一区二区| 国产精品热久久| 亚洲精品不卡| 国产婷婷色一区二区三区四区| 国产精品人妻一区二区三区| 看片网站在线观看| 一本色道久久综合亚洲aⅴ蜜桃| 欧美成人一区二区三区片免费| 91福利在线免费| 免费在线激情视频| 高清国产一区二区三区四区五区| 婷婷婷国产在线视频| 欧美激情在线一区| 欧美做受高潮电影o| 亚洲三区在线观看无套内射| 国产精品正在播放| 亚洲制服丝袜在线播放| 亚洲天堂开心观看| 久久免费精彩视频| 欧美a级一区| 制服丝袜成人动漫| 久久色在线播放| 国产精品迅雷| 性爱在线免费视频| 国产成人免费观看视频| 97在线观看免费高清视频| 伊人网中文字幕| 国产麻豆精品一区二区| 久久久久久久久久久黄色| 中文字幕理伦片免费看| 伊人春色在线观看| 久久国产加勒比精品无码| 91亚洲精品久久久蜜桃网站| 91首页免费视频| 国产午夜手机精彩视频| 啪啪一区二区三区| 凸凹人妻人人澡人人添| 一区二区成人在线视频| 天美星空大象mv在线观看视频| 久久九九久精品国产免费直播| 免费久久99精品国产自在现线| 无国产精品白浆是免费| 成人春色在线观看免费网站| 岛国视频午夜一区免费在线观看| 国产精品色婷婷| 久久99精品久久久久久秒播放器| 亚洲春色综合另类校园电影| 亚洲精品成人av久久| 精品国产亚洲AV| 超鹏97在线| wwwxxx在线观看| 俄罗斯精品一区二区| 国产乱子伦精品无码专区| 亚洲欧洲日本精品| 91久久国产婷婷一区二区| 久久精品免费看| 国产九色精品成人porny| 日韩美一区二区| 国产精品老女人视频| 麻豆精品在线播放| 久久午夜精品| 久久se精品一区精品二区| 中文字幕久久精品| 欧美精品videosex牲欧美| 韩国三级大全久久网站| 妖精视频一区二区三区免费观看| 日韩视频国产视频| 久久亚洲综合国产精品99麻豆精品福利| 欧美成人免费电影| 嫩草影院中文字幕| 日韩美女网站| 一级二级黄色片| 日韩av在线免费| 日韩成人伦理电影在线观看|