日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
jQuery調(diào)用WebService返回JSON數(shù)據(jù)

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)上找一下這方面的資料來看一下,這里就不多說了,或者我以后再寫一篇這方面的文章。

創(chuàng)新互聯(lián)是一家業(yè)務(wù)范圍包括IDC托管業(yè)務(wù),雅安服務(wù)器托管、主機(jī)租用、主機(jī)托管,四川、重慶、廣東電信服務(wù)器租用,內(nèi)蒙古服務(wù)器托管,成都網(wǎng)通服務(wù)器托管,成都服務(wù)器租用,業(yè)務(wù)范圍遍及中國大陸、港澳臺以及歐美等多個國家及地區(qū)的互聯(lián)網(wǎng)數(shù)據(jù)服務(wù)公司。

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

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

 
 
 
 
  1. using System.Web.Script.Services;  
  2. using System.Web.Services;  
  3. namespace WebService35  
  4. {  
  5.     ///   
  6.     /// WebService1 的摘要說明  
  7.     ///   
  8.     [WebService(Namespace = "http://tempuri.org/")]  
  9.     [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]  
  10.     [System.ComponentModel.ToolboxItem(false)]  
  11.     // 若要允許使用 ASP.NET AJAX 從腳本中調(diào)用此 Web 服務(wù),請取消對下行的注釋。  
  12.     [System.Web.Script.Services.ScriptService]  
  13.     public class WebService1 : System.Web.Services.WebService  
  14.     {  
  15.         [WebMethod]  
  16.         [ScriptMethod(UseHttpGet = false)]  
  17.         public string WS1()  
  18.         {  
  19.             return "POST無參數(shù)";  
  20.         }  
  21.         [WebMethod]  
  22.         [ScriptMethod(UseHttpGet = false)]  
  23.         public string WS2(string s)  
  24.         {  
  25.             return s;  
  26.         }  
  27.         [WebMethod]  
  28.         [ScriptMethod(UseHttpGet = true)]  
  29.         public string WS3()  
  30.         {  
  31.             return "GET無參數(shù)";  
  32.         }  
  33.         [WebMethod]  
  34.         [ScriptMethod(UseHttpGet = true)]  
  35.         public string WS4(string s)  
  36.         {  
  37.             return s;  
  38.         }  
  39.     }     
 
 
 
 
 
  1. function fun1() {  
  2.            $.ajax({  
  3.                url: "WebService1.asmx/WS1",  
  4.                type: "POST",  
  5.                dataType: "json",  
  6.                contentType: "application/json; charset=utf-8",  
  7.                data: "",  
  8.                success: function(json) {  
  9.                    alert(json.d);  
  10.                },  
  11.                error: function(x, e) {  
  12.                    alert(x.responseText);  
  13.                },  
  14.                complete: function(x) {  
  15.                    alert(x.responseText);  
  16.                }  
  17.            });  
  18.        } 
 

上面的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為{}。

 
 
 
 
  1. function fun1() {  
  2.             $.ajax({  
  3.                 url: "WebService1.asmx/WS1",  
  4.                 type: "POST",  
  5.                 dataType: "json",  
  6.                 contentType: "application/json; charset=utf-8",  
  7.                 data: "{}",  
  8.                 success: function(json) {  
  9.                     alert(json.d);  
  10.                 },  
  11.                 error: function(x, e) {  
  12.                     alert(x.responseText);  
  13.                 },  
  14.                 complete: function(x) {  
  15.                     alert(x.responseText);  
  16.                 }  
  17.             });  
  18.         } 

現(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”,這樣就可以了。

  
  
  
  
  1. function fun1() {  
  2.             $.ajax({  
  3.                 url: "WebService1.asmx/WS1",  
  4.                 type: "POST",  
  5.                 dataType: "json",  
  6.                 data: "",  
  7.                 beforeSend: function(x) {  
  8.                     x.setRequestHeader("Content-Type", "application/json; charset=utf-8");  
  9.                 },  
  10.                 success: function(json) {  
  11.                     alert(json.d);  
  12.                 },  
  13.                 error: function(x, e) {  
  14.                     alert(x.responseText);  
  15.                 },  
  16.                 complete: function(x) {  
  17.                     alert(x.responseText);  
  18.                 }  
  19.             });  
  20.         } 

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

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

 
 
 
 
  1. function fun1() {  
  2.             $.ajax({  
  3.                 url: "WebService1.asmx/WS1",  
  4.                 type: "POST",  
  5.                 dataType: "json",  
  6.                 contentType: "application/json; charset=utf-8",  
  7.                 data: "{}",  
  8.                 beforeSend: function(x) {  
  9.                     x.setRequestHeader("Content-Type", "application/json; charset=utf-8");  
  10.                 },  
  11.                 success: function(json) {  
  12.                     alert(json.d);  
  13.                 },  
  14.                 error: function(x, e) {  
  15.                     alert(x.responseText);  
  16.                 },  
  17.                 complete: function(x) {  
  18.                     alert(x.responseText);  
  19.                 }  
  20.             });  
  21.         } 

那么在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ù)了。

  
  
  
  
  1. function fun1() {  
  2.             $.ajax({  
  3.                 url: "WebService1.asmx/WS1",  
  4.                 type: "POST",  
  5.                 dataType: "json",  
  6.                 data: "{}",  
  7.                 beforeSend: function(x) {  
  8.                     x.setRequestHeader("Content-Type", "application/json; charset=utf-8");  
  9.                 },  
  10.                 success: function(json) {  
  11.                     alert(json.d);  
  12.                 },  
  13.                 error: function(x, e) {  
  14.                     alert(x.responseText);  
  15.                 },  
  16.                 complete: function(x) {  
  17.                     alert(x.responseText);  
  18.                 }  
  19.             });  
  20.         } 

從下圖可以看到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ù)')+"}"了。

  
  
  
  
  1. function fun2() {  
  2.             $.ajax({  
  3.                 url: "WebService1.asmx/WS2",  
  4.                 contentType: "application/json; charset=utf-8",  
  5.                 type: "POST",  
  6.                 dataType: "json",  
  7.                 data: "{s:'POST有參數(shù)'}",  
  8.                 success: function(json) {  
  9.                     alert(json.d);  
  10.                 },  
  11.                 error: function(x, e) {  
  12.                     alert(x.responseText); ;  
  13.                 },  
  14.                 complete: function(x) {  
  15.                     alert(x.responseText);  
  16.                 }  
  17.             });  
  18.         } 

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

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

  
  
  
  
  1. function fun3() {  
  2.      $.ajax({  
  3.          url: "WebService1.asmx/WS3",  
  4.          type: "GET",  
  5.          dataType: "json",  
  6.          data: "",  
  7.          contentType: "application/json; charset=utf-8",  
  8.          success: function(json) {  
  9.              alert(json.d);  
  10.          },  
  11.          error: function(x, e) {  
  12.              alert(x.responseText);  
  13.          },  
  14.          complete: function(x) {  
  15.              alert(x.responseText);  
  16.          }  
  17.      });  
  18.  } 

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

下面的代碼是正確的用GET方法調(diào)用無參數(shù)的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方法調(diào)用有參數(shù)的WebService方法。

        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ù)為亂碼。

另:本文為原創(chuàng),如要轉(zhuǎn)載,請注明出處。

相關(guān)代碼地址:http://download.csdn.net/source/1510113。


分享題目:jQuery調(diào)用WebService返回JSON數(shù)據(jù)
網(wǎng)站鏈接:http://www.dlmjj.cn/article/copjjpj.html