淺析ASP.NET MVC中的TempData機(jī)制
開發(fā)環(huán)境:Windows 2008, VS 2008 SP1, ASP.NET MVC 1.0
一. ASP.NET MVC中的TempData
在ASP.NET MVC框架的ControllerBase中存在一個(gè)叫做TempData的Property,它的類型為TempDataDictionary,顧名思義是一個(gè)字典類。TempData在ASP.NET MVC中的作用是:可用于在Action執(zhí)行過程之間傳值。簡單的說,你可以在執(zhí)行某個(gè)Action的時(shí)候,將數(shù)據(jù)存放在TempData中,那么在下一次Action執(zhí)行過程中可以使用TempData中的數(shù)據(jù)。
如:
上面的代碼中,Index()給TempData添加了一個(gè)鍵值對,假設(shè)我們先請求Index這個(gè)Action,接著請求Index2這個(gè)Action,那么在Index2中,我們便可以得到之前添加到TempData的鍵值對。有趣的是,這時(shí)如果再次請求Index2,那么從TempData中讀到的MyName的值會(huì)是null。于是,我們需要了解TempData的生命周期。
二. TempData的生命周期
我們知道Http是無狀態(tài)的,為什么TempData可以在兩次請求之前傳遞數(shù)據(jù)呢?很明顯,這個(gè)數(shù)據(jù)必定是已某種形式保存了。查看Controller類的源代碼,很容易的找到了我們想要的東西:
從上面的代碼可以看出,每次在執(zhí)行Action之前,都要調(diào)用一下TempData.Load()方法,執(zhí)行完Action之后,再調(diào)用一下TempData.Save()方法。另外這里還有一個(gè)重要成員TempDataProvider。
閱讀了相關(guān)源代碼之后,真相大白了。
TempData.Load()
TempData.Save()
TempDataProvider用于暫存數(shù)據(jù)。在TempData.Load()方法中,TempDataProvider中保存的數(shù)據(jù)會(huì)被讀到TempData中,供Action調(diào)用過程中使用。Action執(zhí)行完后,TempData.Save()所作的事情則是,移除TempData中任何沒有被更新的鍵值對,然后再將TempData中的數(shù)據(jù)保存,供下一次調(diào)用使用(注:也就是說,只有更新過的,以及新添加的鍵值對才能再下次request中繼續(xù)使用)。為什么TempData中的數(shù)據(jù)需要迅速被清除呢?很簡單,節(jié)約內(nèi)存嘛。
三. ITempDataProvider
前面提到的TempDataProvider是Controller的一個(gè)Property,它的定義是這樣的:
這里我們看到了一個(gè)默認(rèn)實(shí)現(xiàn)的SessionStateTempDataProvider類。也就是說,默認(rèn)情況下,ASP.NET MVC通過SessionStateTempDataProvider來保存TempData的數(shù)據(jù)。很明顯,數(shù)據(jù)是存在Session中的,也就是說,如果你禁用SessionState,那么你的頁面就報(bào)異常了。
ASP.NET MVC生來就是被設(shè)計(jì)為易擴(kuò)展的,我們可以很容易通過實(shí)現(xiàn)自己的ITempDataProvider類來替換這個(gè)默認(rèn)的SessionStateTempDataProvider。需要注意的是,TempDataProvider存放的數(shù)據(jù)必需具有用戶獨(dú)立性。
ITempDataProvider接口定義非常簡單:
在MvcFutures中,你也可以找到一個(gè)CookieTempDataProvider,提供了將TempData存儲(chǔ)在Cookie中的實(shí)現(xiàn)。
【編輯推薦】