日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

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

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
教你如何構建簡單WebAPI

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

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

  如何創(chuàng)建一個通過HTTP GET訪問的Web Api

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

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

  如何在Api上啟用OData uri查詢

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

設置站點的端口號為9000

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

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

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

選擇安裝,NuGet就會下載所有所需的軟件包,現(xiàn)在可以開始開發(fā)Web Api。

  3、創(chuàng)建一個Contacts Api類

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

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

  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("api/contacts");

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

 
 
 
 
  1.   publicstaticvoidRegisterRoutes(RouteCollection routes)
  2.   {
  3.   routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
  4.   routes.MapServiceRoute("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.   );
  9.   }

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

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

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

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

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

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

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

 
 
 
 
  1.   [WebGet(UriTemplate = "")]
  2.   publicIQueryable Get()
  3.   {
  4.   var contacts = newList()
  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提供了一些“內容協(xié)商”機制 — 當有多個可得的表現(xiàn)形式的時候,對特定的響應選擇最好的表現(xiàn)形式的處理過程。

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

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

  服務器驅動協(xié)商是有優(yōu)點的,當從可行的表現(xiàn)形式里進行選擇的算法對用戶代理進行描述是比較困難的時候,或者當服務器期望發(fā)送“最好的猜測”給客戶端而只通過一個響應(以避免后續(xù)請求的回路(一個請求會返回一個響應)延遲如果此“最好的猜測“對用戶適合的時候)的時候。為了改善服務器的猜測,用戶代理應該包含請求頭域(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格式的數(shù)據(jù):

8、啟用OData 查詢支持

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

  returncontacts.AsQueryable();

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

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

  總結

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

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

  如何創(chuàng)建一個通過HTTP GET訪問的Web Api

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

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

  如何在Api上啟用OData uri查詢

  出處:http://shanyou.cnblogs.com/


網(wǎng)頁標題:教你如何構建簡單WebAPI
網(wǎng)頁網(wǎng)址:http://www.5511xx.com/article/dhgjoid.html