由于HTTP協(xié)議的無狀態(tài)特性,導(dǎo)致在ASP.NET編程中,每個(gè)請(qǐng)求都會(huì)在服務(wù)端從頭到執(zhí)行一次管線過程, 對(duì)于ASP.NET頁面來說,Page對(duì)象都會(huì)重新創(chuàng)建,所有控件以及內(nèi)容都會(huì)重新生成, 因此,如果希望上一次的頁面狀態(tài)能夠在后續(xù)頁面中保留,則必需引入狀態(tài)管理功能。
ASP.NET為了實(shí)現(xiàn)狀態(tài)管理功能,提供了8種方法,可幫助我們?cè)陧撁嬷g或者整個(gè)用戶會(huì)話期間保留狀態(tài)數(shù)據(jù)。 這些方法分為二類:視圖狀態(tài)、控件狀態(tài)、隱藏域、Cookie 和查詢字符串會(huì)以不同方式將數(shù)據(jù)發(fā)送到客戶端上。 而應(yīng)用程序狀態(tài)、會(huì)話狀態(tài)和配置文件屬性(Profile)則會(huì)將數(shù)據(jù)存儲(chǔ)到服務(wù)端。 雖然每種方法都有不同的優(yōu)點(diǎn)和缺點(diǎn),對(duì)于小的項(xiàng)目來說,可以選擇自己認(rèn)為最容易使用的方法, 然而,對(duì)于有著較高要求的程序,尤其是對(duì)于性能與擴(kuò)展性比較關(guān)注的程序來說, 選擇不同的方法最終導(dǎo)致的差別可能就非常大了。
在這篇博客中,我將談?wù)勛约簩?duì)ASP.NET狀態(tài)管理方面的一些看法。
注意:本文的觀點(diǎn)可能并不合適開發(fā)小型項(xiàng)目,因?yàn)槲谊P(guān)注的不是易用性。
hidden-input( 隱藏域)
hidden-input 這個(gè)名字我是取的,表示所有type="hidden"的input標(biāo)簽元素。 在中文版的MSDN中,也稱之為 隱藏域 。 hidden-input通常存在于HTML表單之內(nèi),它不會(huì)顯示到頁面中, 但可以隨表單一起提交,因此,經(jīng)常用于維護(hù)當(dāng)前頁面的相關(guān)狀態(tài),在服務(wù)端我們可以使用Request.Form[]來訪問這些數(shù)據(jù)。
一般說來,我通常使用hidden-input來保存一些中間結(jié)果,用于在多次提交中維持一系列狀態(tài), 或者用它來保存一些固定參數(shù)用來提交給其它頁面(或網(wǎng)站)。 在這些場(chǎng)景中,我不希望用戶看到這些數(shù)據(jù),因此,使用hidden-input是比較方便的。
關(guān)于表單的更多介紹可參考我的博客:細(xì)說 Form (表單)
在ASP.NET WebForm框架中,我們可以使用HiddenField控件來創(chuàng)建一個(gè)hidden-input控件,并可以在服務(wù)端操作它, 還可以直接以手寫的方式使用隱藏域,例如:
<input type="hidden" name="hidden-1" value="aaaaaaa" /> <input type="hidden" name="hidden-2" value="bbbbbbb" /> <input type="hidden" name="hidden-3" value="ccccccc" />
另外,我們還可以調(diào)用ClientScript.RegisterHiddenField()方法來創(chuàng)建隱藏域:
ClientScript.RegisterHiddenField("hidden-4", "ddddddddd");
輸出結(jié)果:
<input type="hidden" name="hidden-4" id="hidden-4" value="ddddddddd" />
這三種方法對(duì)于生成的HTML代碼來說,主要差別在于它們出現(xiàn)位置不同:
1. HiddenField控件:由HiddenField的出現(xiàn)位置來決定(在form內(nèi)部)。
2. RegisterHiddenField方法:在form標(biāo)簽的開頭位置。
3. hidden-input:你寫在哪里就是哪里。
優(yōu)點(diǎn):
1. 不需要任何服務(wù)器資源:隱藏域隨頁面一起發(fā)送到客戶端。
2. 廣泛的支持:幾乎所有瀏覽器和客戶端設(shè)備都支持具有隱藏域的表單。
3. 實(shí)現(xiàn)簡(jiǎn)單:隱藏域是標(biāo)準(zhǔn)的 HTML 控件,不需要復(fù)雜的編程邏輯。
缺點(diǎn):
1. 不能在多頁面跳轉(zhuǎn)之間維持狀態(tài)。
2. 用戶可見,保存敏感數(shù)據(jù)時(shí)需要加密。