• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            流量統計:
            Rixu Blog (日需博客)
            日需博客,每日必需來踩踩哦..
            posts - 108,comments - 54,trackbacks - 0

            WCF Web API支持多個宿主環境:自宿主(windows服務或者控制臺)和IIS宿主(ASP.NET webform/mvc)。這個入門文章主要演示在ASP.NET MVC3網站宿主:

            如何使用NuGet向項目中添加Web Api引用

            如何創建一個通過HTTP GET訪問的Web Api

            如何通過ASP.NET routes宿主一個Web Api

            如何通過瀏覽器或者Fiddler訪問Web Api

            如何在Api上啟用OData uri查詢

            1、創建一個基本的解決方案:使用VS2010新建一個空的ASP.NET MVC 3 Web Application

            設置站點的端口號為9000

            2、向解決方案中加入Web Api的引用

            通過NuGet來添加Web api的程序集引用,右擊項目屬性,選擇“Manage NuGet Packages”

            在NuGet管理擴展器上查詢Online的”webapi.all“

            選擇安裝,NuGet就會下載所有所需的軟件包,現在可以開始開發Web Api。

            3、創建一個Contacts Api類

            右擊項目ContactManager選擇添加一個文件夾,取名”APIs“,然后在APIs文件夾上右擊添加類,類名叫做ContactsApi:

            1. usingSystem.ServiceModel;  
            2. namespaceContactManager.APIs  
            3. {  
            4. [ServiceContract]  
            5. publicclassContactsApi  
            6. {  
            7. }  

            ContractsApi 加了ServiceContractAttribute表示這是一個WCF 服務,將通過HTTP方式暴露出來。

            4、通過ASP.NET routing注冊ContractsApi

            Api需要通過ASP.NET mvc宿主,使用ASP.net Route的MapServiceRoute擴展方法把它注冊進去。切換到global.asax.cs文件,添加以下引用

            usingContactManager.APIs;

            usingMicrosoft.ApplicationServer.Http.Activation;

            在RegisterRoutes方法里加入下述代碼

            routes.MapServiceRoute<ContactsApi>("api/contacts");

            下面的黃色部分很重要,MVC的默認路由是映射到controller + action

            1. publicstaticvoidRegisterRoutes(RouteCollection routes)  
            2. {  
            3. routes.IgnoreRoute("{resource}.axd/{*pathInfo}");  
            4. routes.MapServiceRoute<ContactsApi>("api/contacts");routes.MapRoute(  
            5. "Default"// Route name  
            6. "{controller}/{action}/{id}"// URL with parameters  
            7. new{ controller = "Home", action = "Index", id = UrlParameter.Optional } // Parameter defaults  
            8. );  

            MapServiceRoute需要一個泛型參數指定服務(API),以及一個將被追加到IIS base url的路徑。在這里,我們指定的“contacts”,也就是宿主為“http://localhost:9000/api/contacts”。

            5. 通過一個HTTP Get 方法暴露contacts:首先創建一個poco(Plain Old C#)Contract類,代表我們在api上傳遞的聯系人,本質上就是一個DTO(數據傳輸對象),在HTTP上我們把它作為資源,然后創建一個HTTP Get方法暴露資源。

            右擊項目ContactManager項目選擇添加新的文件夾“Resources”,在Resources文件下創建一個新的類Contact。

            1. namespaceContactManager.Resources  
            2. {  
            3. publicclassContact  
            4. {  
            5. publicintContactId { getset; }  
            6. publicstringName { getset; }  
            7. }  

            返回到ContactApi類,添加下述引用:

            1. usingSystem.ServiceModel.Web;  
            2. usingContactManager.Resources; 

            添加一個Get方法返回所有的contracts

            1. [WebGet(UriTemplate = "")]  
            2. publicIQueryable<Contact> Get()  
            3. {  
            4. var contacts = newList<Contact>()  
            5. {  
            6. newContact {ContactId = 1, Name = "Phil Haack"},  
            7. newContact {ContactId = 2, Name = "HongMei Ge"},  
            8. newContact {ContactId = 3, Name = "Glenn Block"},  
            9. newContact {ContactId = 4, Name = "Howard Dierking"},  
            10. newContact {ContactId = 5, Name = "Jeff Handley"},  
            11. newContact {ContactId = 6, Name = "Yavor Georgiev"}  
            12. };  
            13. returncontacts.AsQueryable();  
            14.  } 

            Get方法上加了WebGet Attribute表示這是一個HTTP Get。注意這里的UriTemplate被設置為“”,默認情況下,操作的Uri是方法名Get,在這種情況下,我們是在Route中設置的Uri。

            6、通過瀏覽器查詢Contracts.按F5運行項目,然后再瀏覽器地址欄中輸入http://localhost:9000/api/contacts

            7、查詢返回Json格式的Contracts。HTTP提供了一些“內容協商”機制 — 當有多個可得的表現形式的時候,對特定的響應選擇最好的表現形式的處理過程。

            服務器驅動協商(Server-driven Negotiation)

            如果響應的最好的表現形式的選擇是通過服務器上的算法來實現,那么這種方式的協商稱做服務器驅動協商。選擇是基于響應可得的表現形式(根據不同的維度,響應會不同;例如,語言,內容編碼,等等)和請求消息里特定的頭域或關于請求的其他信息(如:網絡客戶端的地址)。

            服務器驅動協商是有優點的,當從可行的表現形式里進行選擇的算法對用戶代理進行描述是比較困難的時候,或者當服務器期望發送“最好的猜測”給客戶端而只通過一個響應(以避免后續請求的回路(一個請求會返回一個響應)延遲如果此“最好的猜測“對用戶適合的時候)的時候。為了改善服務器的猜測,用戶代理應該包含請求頭域(Accept,Accept-Language,Accept-Encoding,等等),這些頭域能描述它對響應的喜好。

            Web api返回的響應很容易添加一種媒體類型(media types )。

            打開Fiddler,在“Request builder”欄輸入地址“http://localhost:9000/api/contacts”,然后移動到“Request Headers”在“User-Agent” 項下方添加 “Accept: application/json”

            按下 Exectue按鈕,雙擊左邊的Panel查看HTTP的response,切換到“Raw”Tab,你可以看到下面的json格式的數據:

            8、啟用OData 查詢支持

            Web API支持OData協議,接受OData的URI格式查詢,當OData 查詢到達Web Api, 在返回客戶端之前在服務端會進行必要的過濾和排序。查詢使用IQueryable 接口,服務端并沒有去查詢所有的數據,發送過濾和排序到服務端。

            returncontacts.AsQueryable();

            運行程序,在瀏覽器里輸入 http://localhost:9000/api/contacts?$Top=4&$OrderBy=Name,看到瀏覽器之返回了按名字排序的top 4個contract

            也可以通過Fidder去查詢,具體可參照第7步。

            總結

            通過這個Quick start,我們學習到了以下內容

            如何使用NuGet向項目中添加Web Api引用

            如何創建一個通過HTTP GET訪問的Web Api

            如何通過ASP.NET routes宿主一個Web Api

            如何通過瀏覽器或者Fiddler訪問Web Api

            如何在Api上啟用OData uri查詢

            Logo
            作者:Gezidan
            出處:http://www.rixu.net    
            本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
            本文轉載自 http://developer.51cto.com/art/201109/291756.htm
            posted on 2011-09-28 09:39 日需博客 閱讀(929) 評論(0)  編輯 收藏 引用
            精品久久久久久亚洲| 热久久国产欧美一区二区精品 | 精品99久久aaa一级毛片| 色欲久久久天天天综合网精品| 国产69精品久久久久APP下载| 国产精品成人99久久久久| 日韩精品国产自在久久现线拍 | 久久国产成人| 国产免费福利体检区久久| 91久久精品国产91性色也| 国产69精品久久久久9999| 久久一本综合| 国产亚洲色婷婷久久99精品91| 丁香狠狠色婷婷久久综合| 99久久综合狠狠综合久久止| 色综合久久综精品| 国产精品嫩草影院久久| 无码国内精品久久人妻麻豆按摩| 99久久国产精品免费一区二区| 久久精品中文字幕无码绿巨人| 久久久91精品国产一区二区三区| 99久久www免费人成精品| 激情久久久久久久久久| 99久久精品国产一区二区 | 久久精品黄AA片一区二区三区| AV狠狠色丁香婷婷综合久久| 99久久国产主播综合精品| 亚洲午夜精品久久久久久浪潮| 婷婷五月深深久久精品| 久久av高潮av无码av喷吹| 国产精品久久新婚兰兰| 日本免费一区二区久久人人澡 | 亚洲级αV无码毛片久久精品| 久久免费高清视频| 中文字幕久久波多野结衣av| 色综合久久88色综合天天| 99999久久久久久亚洲| 久久精品天天中文字幕人妻| 国产精品午夜久久| 色欲久久久天天天综合网精品| 国产精品99久久久久久猫咪|