ASP.NET MVC4入門教程(九):查詢詳細信息和刪除記錄
在本教程中,您將查看自動生成的Details和Delete方法。
查詢詳細信息和刪除記錄打開Movie控制器并查看Details方法。
public ActionResult Details(int id = 0) { Movie movie = db.Movies.Find(id); if (movie == null) { return HttpNotFound(); } return View(movie); }
Code First 使得您可以輕松的使用Find方法來搜索數(shù)據(jù)。一個重要的安全功能內(nèi)置到了方法中。方法首先驗證Find方法已經(jīng)找到了一部電影,然后再執(zhí)行其它代碼。例如,黑客可以通過更改http://localhost:xxxx/Movies/Details/1到http://localhost:xxxx/Movies/Details/12345 (或某些其它值,不代表實際影片的值)從而使得鏈接URL 出現(xiàn)錯誤。如果您沒有檢測是否找到了Movie, null Movie會導(dǎo)致出現(xiàn)數(shù)據(jù)錯誤。
查看Delete和DeleteConfirmed方法。
// GET: /Movies/Delete/5 public ActionResult Delete(int id = 0) { Movie movie = db.Movies.Find(id); if (movie == null) { return HttpNotFound(); } return View(movie); } // // POST: /Movies/Delete/5 [HttpPost, ActionName("Delete")] public ActionResult DeleteConfirmed(int id = 0) { Movie movie = db.Movies.Find(id); if (movie == null) { return HttpNotFound(); } db.Movies.Remove(movie); db.SaveChanges(); return RedirectToAction("Index"); }
請注意,Delete的HTTP Get 方法不會刪除指定的電影,它返回刪除電影的視圖,您可以在此視圖中提交 (HttpPost) 刪除電影。如果使用GET 請求執(zhí)行刪除操作(或者執(zhí)行編輯操作,創(chuàng)建操作或者更改數(shù)據(jù)的任何其它操作) 開辟了一個安全漏洞。對此的詳細信息,請參閱斯蒂芬 · 瓦爾特的博客ASP.NET MVC Tip #46 — Don't use Delete Links because they create Security Holes.
將刪除數(shù)據(jù)的HttpPost方法命名為唯一簽名或名稱的 DeleteConfirmed 方法。這兩個方法的簽名如下所示:
// GET: /Movies/Delete/5 public ActionResult Delete(int id = 0) // // POST: /Movies/Delete/5 [HttpPost, ActionName("Delete")] public ActionResult DeleteConfirmed(int id = 0)
公共語言運行時 (CLR)重載方法時,需要方法具有獨特唯一的簽名 (方法名稱相同但不同的參數(shù)列表)。但是,在這里您需要兩種刪除方法 — — 一個 GET方法和一個POST方法它們都具有相同的簽名。(他們都需要接受一個整數(shù)作為參數(shù))。
要解決這一點,可以有幾種辦法。一是使用不同的方法名稱。這是框架代碼在前面的示例中所使用的方法。然而,這就帶來了一個小問題: ASP.NET 將部分的 URL按名稱映射到操作方法,如果您重命名了方法,通常Routing將無法找到該方法。解決方法是您在示例中看到的,將ActionName("Delete")屬性添加到DeleteConfirmed 方法。這會有效的執(zhí)行Routing系統(tǒng)的Url映射,這樣一個包含/Delete/的 POST 請求的URL 將找到DeleteConfirmed 方法。
另一個常見的方法,來避免具有相同名稱和簽名的方法,是人為地改變POST 方法,包括未使用參數(shù)的簽名。例如,有些開發(fā)人員添加參數(shù)類型 FormCollection,FormCollection是會傳遞給 POST 方法的,然后根本不使用此參數(shù):
public ActionResult Delete(FormCollection fcNotUsed, int id = 0) { Movie movie = db.Movies.Find(id); if (movie == null) { return HttpNotFound(); } db.Movies.Remove(movie); db.SaveChanges(); return RedirectToAction("Index"); }
您現(xiàn)在有一個完整的 ASP.NET MVC 應(yīng)用程序并在本地的 DB 數(shù)據(jù)庫中存儲數(shù)據(jù)。您可以創(chuàng)建、 讀取、 更新、 刪除和搜索電影。
如果您想要部署應(yīng)用程序,最好先在您本地的IIS 7 服務(wù)器上測試一下您的應(yīng)用程序。您可以使用此 Web Platform Installer 鏈接啟用IIS服務(wù)器的 ASP.NET 應(yīng)用程序的設(shè)置。請參閱下面的部署鏈接:
· Test your ASP.NET MVC or WebForms Application on IIS 7 in 30 seconds
· ASP.NET Deployment Content Map
· Web Application Projects Deployment
現(xiàn)在鼓勵您開始學習中級內(nèi)容 Creating an Entity Framework Data Model for an ASP.NET MVC Application 和 MVC Music Store 教程, 瀏覽 ASP.NET articles on MSDN,的文章,再看看很多的視頻和資源:http://asp.net/mvc來了解更多關(guān)于 ASP.NET MVC 的信息 ! ASP.NET MVC forums 論壇是一個好地方,可以用來問您想要知道的問題。
- 基于Asp.Net MVC4 Bundle捆綁壓縮技術(shù)的介紹
- 使用asp.net MVC4中的Bundle遇到的問題及解決辦法分享
- ASP.NET MVC4之js css文件合并功能(3)
- ASP.NET MVC4 HtmlHelper擴展類,實現(xiàn)分頁功能
- ASP.NET MVC4入門教程(一):入門介紹
- ASP.NET MVC4入門教程(二):添加一個控制器
- ASP.NET MVC4入門教程(三):添加一個視圖
- ASP.NET MVC4入門教程(四):添加一個模型
- ASP.NET MVC4入門教程(五):從控制器訪問數(shù)據(jù)模型
- ASP.NET MVC4入門教程(六):驗證編輯方法和編輯視圖
- ASP.NET MVC4入門教程(七):給電影表和模型添加新字段
- ASP.NET MVC4入門教程(八):給數(shù)據(jù)模型添加校驗器
相關(guān)文章
在ASP.NET 2.0中操作數(shù)據(jù)之四十二:DataList和Repeater數(shù)據(jù)排序(一)
本文主要介紹利用ObjectDataSource的Selecting事件進行DataList和Repeater數(shù)據(jù)排序的方法,DropDownList隱式的為我們將sort expression 和 direction保存在它的view state里,進行分頁時從view state中取出條件進行排序。2016-05-05在ASP.NET 2.0中操作數(shù)據(jù)之三:創(chuàng)建母版頁和站點導(dǎo)航
本文主要介紹在ASP.NET如何創(chuàng)建母版頁以及站點地圖等操作,母版頁的實現(xiàn)的功能有點類似自定義用戶控件,可以實現(xiàn)網(wǎng)站頁面統(tǒng)一的設(shè)計和布局。2016-04-04在ASP.NET 2.0中操作數(shù)據(jù)之四十九:為GridView控件添加RadioButton
本文主要講解ASP.NET 2.0為GridView的每一行添加RadioButton具體方法,并配合Literal控件實現(xiàn)單選的目的。2016-05-05在ASP.NET 2.0中操作數(shù)據(jù)之三十五:使用Repeater和DataList單頁面實現(xiàn)主/從報表
前面已經(jīng)介紹了ASP.NET 2.0中如何使用兩個頁面實現(xiàn)主/從報表,本文主要講解,如何使用一個單獨頁面實現(xiàn)主/從報表。2016-05-05Microsoft .Net Remoting系列教程之三:Remoting事件處理全接觸
本文主要講解.Net Remoting中的Remoting事件處理,需要的朋友可以參考下。2016-05-05使用.Net6中的WebApplication打造最小API
本文詳細講解了使用.Net6中的WebApplication打造最小API,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-12-12解讀ASP.NET 5 & MVC6系列教程(15):MvcOptions配置
這篇文章主要介紹了ASP.NET 5 MVC6中MvcOptions配置方法,需要的朋友可以參考下2016-06-06