成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

教你如何構建簡單Web API

開發 后端
這個入門文章主要演示在ASP.NET MVC3網站宿主,讓各位.NET程序員知道如何構建簡單Web API。

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

  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.   }  
  8.   } 

  返回到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查詢

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

【編輯推薦】

  1. 淺析.NET中的Server push技術
  2. .NET動靜結合編程 接口和委托的約束強度
  3. 使用.NET Array類的Sort方法分類數值
  4. WCF特點具體優勢總結
  5. WCF事件通知具體實現方法詳解

 

責任編輯:彭凡 來源: 博客園
相關推薦

2021-11-07 14:29:13

ChromeAPI 藍牙

2012-06-20 14:34:03

jQuery

2009-09-23 10:14:22

Hibernate

2021-11-22 09:00:00

后端開發CMS

2020-07-28 15:20:43

PythonUI代碼

2019-12-23 10:00:52

PythonFlaskPython Web

2019-05-08 14:37:49

Web服務器HTTP

2020-07-07 07:00:00

Spring WebFREST APIReactive AP

2009-05-12 09:54:09

JavaRestCoC

2021-05-07 09:06:55

GraphQLAPI 以太坊

2021-12-07 06:02:15

Redis Docker運維

2024-01-09 09:09:45

RESTGraphQL

2024-05-23 11:26:02

2022-03-15 12:43:44

Web APIAPI

2009-06-05 10:55:07

struts2 web

2019-12-30 09:00:00

Web 開發代碼

2010-02-04 16:43:50

2023-04-19 07:39:55

RustHTTP服務器

2014-02-19 15:38:42

2016-09-21 12:54:10

CAAS系統鏡像
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品视频免费 | www.久草.com| 天天综合网天天综合色 | 国产高清久久 | 国产免费观看久久黄av片涩av | 午夜精品影院 | 欧产日产国产精品国产 | 一区二区精品 | 久久激情视频 | 黄色片视频 | 成人福利在线 | 久久综合久久久 | 日日干夜夜操 | 特黄色一级毛片 | 国产精品免费在线 | 伊人精品久久久久77777 | 亚洲成人av| 91久久综合亚洲鲁鲁五月天 | 一级毛片视频 | 欧美日韩成人在线 | 国产精品视频网 | 亚洲在线一区二区 | 中文字幕三区 | 一区免费视频 | 欧美一区二区三区在线观看 | 日韩成人高清在线 | 蜜桃黄网 | 97久久久| 国产视频一区二区 | 伊色综合久久之综合久久 | 日韩激情网 | 欧美一级电影免费 | 毛片日韩| 天天天天操 | 成人午夜免费视频 | 国产激情福利 | 懂色中文一区二区三区在线视频 | 国产一区二区精品在线观看 | 亚洲视频在线看 | 天天看逼 | 欧美日韩在线一区二区三区 |