日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

MVC4 WebAPI(一)

發布時間:2025/3/18 c/c++ 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MVC4 WebAPI(一) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

為什么80%的碼農都做不了架構師?>>> ??

不管是因為什么原因,結果是在新出的MVC中,增加了WebAPI,用于提供REST風格的WebService,個人比較喜歡REST風格的WebService,感覺比SOAP要輕量級一些,而且對客戶端的要求也更少,更符合網絡數據傳輸的一般模式,客戶端完全擺脫了代理和管道來直接和WebService進行交互,具體的區別可以參見Web 服務編程,REST 與 SOAP

(一)環境準備

本機的環境是XP+VS2010,需要安裝VS2010 SP1升級包,MVC4升級包,Vs2010安裝SP1后會影響SQLServer2008的自動提示功能,需要在安裝補丁或插件,安裝成功后可以新建如下的 MVC WebAPI 項目

(二)概覽

新生成的WebAPI項目和典型的MVC項目一樣,包含主要的Models,Views,Controllers等文件夾和Global.asax文件


Views對于WebAPI來說沒有太大的用途,Models中的Model主要用于保存Service和Client交互的對象,這些對象默認情況下會被轉換為Json格式的數據進行傳輸,Controllers中的Controller對應于WebService來說是一個Resource,用于提供服務。和普通的MVC一樣,Global.asax用于配置路由規則

(三)Models

和WCF中的數據契約形成鮮明對比的是,MVC WebAPI中的Model就是簡單的POCO,沒有任何別的東西,如,你可以創建如下的Model

public class TestUseMode{public string ModeKey{get;set;}public string ModeValue { get; set; }}

注意:Model必須提供public的屬性,用于json或xml反序列化時的賦值

(四)Controllers

MVC WebAPI中的Controllers和普通MVC的Controllers類似,不過不再繼承于Controller,而改為繼承API的ApiController,一個Controller可以包含多個Action,這些Action響應請求的方法與Global中配置的路由規則有關,在后面結束Global時統一說明

(五)Global

默認情況下,模板自帶了兩個路由規則,分別對應于WebAPI和普通MVC的Web請求,默認的WebAPI路由規則如下

1 routes.MapHttpRoute( 2 name: "DefaultApi", 3 routeTemplate: "api/{controller}/{id}", 4 defaults: new { id = RouteParameter.Optional } 5 );

可以看到,默認路由使用的固定的api作為Uri的先導,按照微軟官方的說法,用于區分普通Web請求和WebService的請求路徑:

Note:?The reason for using "api" in the route is to avoid collisions with ASP.NET MVC routing. That way, you can have "/contacts" go to an MVC controller, and "/api/contacts" go to a Web API controller. Of course, if you don't like this convention, you can change the default route table.

可以看到,默認的路由規則只指向了Controller,沒有指向具體的Action,因為默認情況下,對于Controller中的Action的匹配是和Action的方法名相關聯的:

具體來說,如果使用上面的路由規則,對應下面的Controller:

public class TestController : ApiController{public static List<TestUseMode> allModeList = new List<TestUseMode>();public IEnumerable<TestUseMode> GetAll(){return allModeList;}public IEnumerable<TestUseMode> GetOne(string key){return allModeList.FindAll((mode) => { if (mode.ModeKey.Equals(key)) return true; return false; });}public bool PostNew(TestUseMode mode){allModeList.Add(mode);return true;}public int Delete(string key){return allModeList.RemoveAll((mode) => { if (mode.ModeKey == key) return true; return false; });}public int DeleteAll(){return allModeList.RemoveAll((mode) => { return true; });}public int PutOne(string key, string value){List<TestUseMode> upDataList = allModeList.FindAll((mode) => { if (mode.ModeKey == key) return true; return false; });foreach(var mode in upDataList){mode.ModeValue = value;}return upDataList.Count;}}

?

則,會有下面的對應關系:

簡單使用JS調用上面提供的數據接口

1 function getAll() {2 $.ajax({3 url: "api/Test/",4 type: 'GET',5 success: function (data) {6 document.getElementById("modes").innerHTML = "";7 $.each(data, function (key, val) {8 var str = val.ModeKey + ': ' + val.ModeValue;9 $('<li/>', { html: str }).appendTo($('#modes')); 10 }); 11 } 12 }).fail( 13 function (xhr, textStatus, err) { 14 alert('Error: ' + err); 15 }); 16 } 17 18 19 20 function add() { 21 22 $.ajax({ 23 url: "api/Test/", 24 type: "POST", 25 dataType: "json", 26 data: { "ModeKey": document.getElementById("txtKey").value, "ModeValue": document.getElementById("txtValue").value }, 27 success: function (data) { 28 getAll(); 29 } 30 }).fail( 31 function (xhr, textStatus, err) { 32 alert('Error: ' + err); 33 }); 34 35 } 36 37 function find() { 38 39 $.ajax({ 40 url: "api/Test/" + document.getElementById("txtFindKey").value, 41 type: 'GET', 42 success: function (data) { 43 document.getElementById("modes").innerHTML = ""; 44 $.each(data, function (key, val) { 45 var str = val.ModeKey + ': ' + val.ModeValue; 46 $('<li/>', { html: str }).appendTo($('#modes')); 47 }); 48 } 49 }).fail( 50 function (xhr, textStatus, err) { 51 alert('Error: ' + err); 52 }); 53 } 54 55 function removeAll() { 56 $.ajax({ 57 url: "api/Test/", 58 type: 'DELETE', 59 success: function (data) { 60 document.getElementById("modes").innerHTML = ""; 61 getAll(); 62 } 63 }).fail( 64 function (xhr, textStatus, err) { 65 alert('Error: ' + err); 66 }); 67 } 68 69 function remove() { 70 $.ajax({ 71 url: "api/Test/"+document.getElementById("txtRemoveKey").value, 72 type: 'DELETE', 73 success: function (data) { 74 document.getElementById("modes").innerHTML = ""; 75 getAll(); 76 } 77 }).fail( 78 function (xhr, textStatus, err) { 79 alert('Error: ' + err); 80 }); 81 } 82 83 function update() { 84 $.ajax({ 85 url: "api/Test/", 86 type: 'PUT', 87 dataType: "json", 88 data: { "key": document.getElementById("txtUpdateKey").value, "value": document.getElementById("txtUpdateValue").value }, 89 success: function (data) { 90 document.getElementById("modes").innerHTML = ""; 91 getAll(); 92 } 93 }).fail( 94 function (xhr, textStatus, err) { 95 alert('Error: ' + err); 96 }); 97 }

這樣就實現了最基本的CRUD操作。

(六)路由規則擴展

和普通的MVC一樣,MVC WebAPI支持自定義的路由規則,如:在上面的操作中,路由規則使用

"api/{controller}/{id}"

則限定了使用GET方式利用URL來傳值時,controller后面的接收參數名為id,但是在Controller中,GetOne方法的接收參數名為key,是不會被匹配的,這是只需要新增一個新的路由規則,或修改原先的路由規則為:

"api/{controller}/{key}"

當然,可以對路由進行更深的擴展,如:擴展成和普通MVC一樣的路由:

"api/{controller}/{action}/{id}"

這樣,就要求同時使用Action和HTTP方法進行匹配
當然,根據微軟的說法,這種使用是不被推薦的,因為這不符合大家對WebService的一般認知:

For a RESTful API, you should avoid using verbs in the URIs, because a URI should identify a resource, not an action.

(七)使用Attribute聲明HTTP方法

有沒有感覺默認的使用方法名來匹配HTTP Method的做法很傻??或者我有一些方法是自己用的,不想暴露出來,又該怎么辦?還是使用attribute做這些工作感覺優雅一些,比如,上面的Action我可以更改為:

[HttpGet]public IEnumerable<TestUseMode> FindAll()[HttpGet]public IEnumerable<TestUseMode> FindByKey(string key)[HttpPost]public bool Add(TestUseMode mode)[HttpDelete]public int RemoveByKey(string key)[HttpDelete]public int RemoveAll()[HttpPut]public int UpdateByKey(string key, string value)[NonAction] public string GetPrivateData()

當然,我只列出了方法名,而不是這些方法真的沒有方法體...方法體是不變的,NoAction表示這個方法是不接收請求的,即使以GET開頭。
如果感覺常規的GET,POST,DELETE,PUT不夠用,還可以使用AcceptVerbs的方式來聲明HTTP方法,如:

[AcceptVerbs("MKCOL", "HEAD")]public int UpdateByKey(string key, string value){List<TestUseMode> upDataList = allModeList.FindAll((mode) => { if (mode.ModeKey == key) return true; return false; });foreach(var mode in upDataList){mode.ModeValue = value;}return upDataList.Count;}

******************************************************************************
作者:王坤?
出處:http://www.cnblogs.com/wk1234

轉載于:https://my.oschina.net/garyun/blog/602725

總結

以上是生活随笔為你收集整理的MVC4 WebAPI(一)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 玩弄白嫩少妇xxxxx性 | 国产精九九网站漫画 | 亚洲最新偷拍 | 丁香婷婷六月天 | 久久香蕉网 | 香蕉视频97| 视频一区二区中文字幕 | 天堂成人国产精品一区 | 成人性生交大片免费看96 | 日韩精品一区二区三区视频在线观看 | 中文字幕123区 | 国产黑丝在线播放 | 亚洲av综合色区无码一区爱av | av导航站 | 夜夜涩 | 欧美日本在线看 | 国产特黄一级片 | 中文在线最新版天堂 | 精品视频网 | 午夜网址 | 欧美中文字幕在线播放 | 国产伦精品一区二区 | 国产精品日韩欧美大师 | 日本在线看片 | 亚洲精品无码久久 | 尤物精品在线观看 | 尤物视频免费在线观看 | 欧美在线播放一区 | 欧美日韩精品久久久免费观看 | av一区二区免费 | 一级特级黄色片 | 欧美亚洲色图视频 | 二区三区视频 | 日本高清免费视频 | 一本免费视频 | 原创露脸88av | 国产内射老熟女aaaa∵ | 伊人久久大香线蕉综合75 | 色中色在线视频 | av每日更新在线观看 | 99久久精品国产成人一区二区 | 成人免费观看视频网站 | 日韩欧美国产片 | 日韩乱码一区二区 | 97精品视频在线 | 青草视频在线观看视频 | 电影《走路上学》免费 | 国产精品乱 | 两性午夜免费视频 | 亚洲精品久久久久国产 | 欧美亚洲视频 | 人人搞人人干 | 亚洲国产成人av | 欧美亚洲中文精品字幕 | 在线观看网页视频 | 亚洲色图少妇 | 国产永久免费视频 | 国产夫妻性生活视频 | 亚洲黄色激情 | 日韩精品一区二区三区国语自制 | 欧美另类亚洲 | 三级黄色av | 久久久99久久 | 日韩国产三级 | 性视频网址 | 全部孕妇毛片丰满孕妇孕交 | 激情五月色播五月 | 老熟女高潮一区二区三区 | 肥臀av | 综合亚洲欧美 | 午夜片在线观看 | 精产国品一二三产品蜜桃 | 一级全黄少妇性色生活片 | xxx日韩 | 欧洲亚洲另类 | 激情小说综合 | 91极品蜜桃臀 | sm久久捆绑调教精品一区 | 中文字幕免费高 | 国产精品日 | 夜色成人网 | 波多野结衣免费视频观看 | 最新中文字幕在线观看 | 欧美日韩亚洲精品一区二区 | 久久久极品| 久久超碰精品 | 亚洲一区二区三区久久久成人动漫 | 嫩草影院一区二区三区 | www插插插无码免费视频网站 | 国产成人自拍偷拍 | 亚洲AV无码一区二区三区性 | 自拍超碰在线 | 国产99999| 无码人妻丰满熟妇精品 | 日韩经典在线 | 欧美精品国产精品 | 成人欧美一区二区三区在线观看 | av不卡在线 | 毛片在线网址 |