中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

WCF簡單教程(10) Ajax調用

發布時間:2020-06-13 19:30:19 來源:網絡 閱讀:4125 作者:BoyTNT 欄目:編程語言

第十篇:Ajax調用WCF

好久不更新了,今天寫一寫如何用Ajax調用WCF服務。在WebService時代,只需要加一行[System.Web.Script.Services.ScriptService]就可以使用Ajax調用了(要求.Net 3.5),到了WCF中,要稍微復雜一些。

寫個小DEMO,這回是基于IIS建一個WCF工程,服務端是一個DataService.svc文件,客戶端我們自己寫一個Client.htm。

1、服務端

定義服務契約,沒什么新鮮的,只有一個GetUser方法。(IDataService.cs)

  1. using System; 
  2. using System.ServiceModel; 
  3.  
  4. namespace WebServer 
  5.     [ServiceContract] 
  6.     public interface IDataService 
  7.     { 
  8.         [OperationContract] 
  9.         User GetUser(); 
  10.     } 

實現類也超級簡單,返回一個User對象。(DataService.svc.cs)

  1. using System; 
  2. using System.ServiceModel; 
  3.  
  4. namespace WebServer 
  5.     public class DataService : IDataService 
  6.     { 
  7.         public User GetUser() 
  8.         { 
  9.             return new User { Name = "BoyTNT", Age = 30 }; 
  10.         } 
  11.     } 

其中的User是數據契約,只有兩個成員。(User.cs)

  1. using System; 
  2. using System.Runtime.Serialization; 
  3.  
  4. namespace WebServer 
  5.     [DataContract] 
  6.     public class User 
  7.     { 
  8.         [DataMember] 
  9.         public string Name { getset; } 
  10.         [DataMember] 
  11.         public int Age { getset; } 
  12.     } 

然后是重點的Web.config文件了,要啟用Ajax訪問,需要對endpoint進行一下特殊聲明(綠色注釋部分)。下面只節選了system.serviceModel節點。

  1. <system.serviceModel> 
  2.     <behaviors> 
  3.         <serviceBehaviors> 
  4.             <behavior name="WebServer.DataServiceBehavior"> 
  5.                 <serviceMetadata httpGetEnabled="true" /> 
  6.             </behavior> 
  7.         </serviceBehaviors> 
  8.    <!--增加一個endpoint的Behavior,命名為AjaxBehavior,為其下加一個enableWebScript節點,表示允許使用腳本訪問--> 
  9.         <endpointBehaviors> 
  10.             <behavior name="AjaxBehavior"> 
  11.                 <enableWebScript/> 
  12.             </behavior> 
  13.         </endpointBehaviors> 
  14.     </behaviors> 
  15.     <services> 
  16.         <service behaviorConfiguration="WebServer.DataServiceBehavior"  name="WebServer.DataService"> 
  17.  <!--使用webHttpBinding,并且標明使用上面定義的AjaxBehavior--> 
  18.             <endpoint address="" binding="webHttpBinding" contract="WebServer.IDataService" behaviorConfiguration="AjaxBehavior" /> 
  19.         </service> 
  20.     </services> 
  21. </system.serviceModel> 


2、客戶端

在工程里加一個Client.htm,注意ajax請求不能跨域,因此必須和服務端放到一塊兒。我這里使用了jquery來進行ajax訪問。

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
  2. <html xmlns="http://www.w3.org/1999/xhtml"
  3. <head> 
  4.     <title>接口測試程序</title> 
  5.     <script language="javascript" src="jquery-1.4.2.js"></script> 
  6.     <script language="javascript"
  7.      function executeAjaxQuery() { 
  8.          $.ajax({ 
  9.             "url""DataService.svc/GetUser",    //注意訪問的url的寫法,是服務名+方法名,這點和WebService是一致的 
  10.             "cache"false
  11.             "async"true
  12.             "type""POST"
  13.             "dataType""json"
  14.             "contentType""application/json; charset=utf-8"
  15.             "data": {},     //如果有參數,在這里傳遞 
  16.             success: function (json) { 
  17.                 //結果被封裝到json.d屬性中,數據契約中定義的兩個成員都能取到 
  18.                 $("#result").val("Name=" + json.d.Name + ", Age=" + json.d.Age); 
  19.             }, 
  20.             error: function (x, e) { 
  21.                 $("#result").val(x.responseText); 
  22.             } 
  23.         }); 
  24.      }  
  25.     </script> 
  26. </head> 
  27. <body> 
  28.  
  29. <input type="button" value="獲取用戶" onclick="executeAjaxQuery()" /><br /> 
  30. <textarea id="result" style="width:400px;height:200px"></textarea> 
  31. </body> 
  32. </html> 

OK,運行一下,在結果窗口里應該能收到“Name=BoyTNT, Age=30”。如果抓一下包,能看到服務端返回的內容是:

  1. {"d":{"__type":"User:#WebServer","Age":30,"Name":"BoyTNT"}} 

這就是為什么要從json.d中取數據的原因。

 

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

上虞市| 吉林市| 鄯善县| 灵宝市| 临夏市| 蒲城县| 陕西省| 抚松县| 彰化县| 昂仁县| 阿拉尔市| 任丘市| 西乌珠穆沁旗| 新邵县| 普洱| 绥德县| 哈尔滨市| 新平| 巴东县| 甘德县| 邳州市| 宜宾市| 信阳市| 晋江市| 泽州县| 桃江县| 龙门县| 邢台市| 苍南县| 金山区| 连州市| 连城县| 长顺县| 翁源县| 内丘县| 观塘区| 绿春县| 唐山市| 吉隆县| 泉州市| 丰顺县|