基本理論:
session值是保存在服務(wù)器內(nèi)存上,那么,可以肯定,大量的使用session將導(dǎo)致服務(wù)器負(fù)擔(dān)加重.而viewstate由于只是將數(shù)據(jù)存入到頁面隱藏控件里,不再占用服務(wù)器資源,因此,我們可以將一些需要服務(wù)器"記住"的變量和對象保存到viewstate里面.而sesson則只應(yīng)該應(yīng)用在需要跨頁面且與每個訪問用戶相關(guān)的變量和對象存儲上.另外,session在默認(rèn)情況下20分鐘就過期,而viewstate則永遠(yuǎn)不會過期.
數(shù)據(jù)類型:
但viewstate并不是能存儲所有的.net類型數(shù)據(jù),它僅僅支持String、Integer、Boolean、Array、ArrayList、Hashtable以及自定義的一些類型.
其他考慮
當(dāng)然,任何事物都有兩面性,使用viewstate會增加頁面html的輸出量,占用更都的帶寬,這一點(diǎn)是需要我們慎重考慮的.另外,由于所有的viewstate都是存儲在一個隱藏域里面,用戶可以很容易的通過查看源碼來看到這個經(jīng)過base64編碼的值.然后再經(jīng)過轉(zhuǎn)換就可以獲取你存儲其中的對象和變量值.
其實(shí),對于viewstate的安全性問題,asp.net還給我們提供了更多的選擇.一般如果要保護(hù)viewstate有兩種方式:一種是防篡改,一種是加密.一說到防篡改,我們就想起了使用散列代碼.沒錯,我們可以在頁面頂部加入如下代碼:PageEnableViewStateMAC=true。這樣asp.net就會自動的在viewstate中追加一個散列碼,在頁面回傳時,服務(wù)器根據(jù)回傳的viewstate生成一個散列碼,再與回傳的散列碼相比較,如果不對,則丟棄該viewstate,同時控件將恢復(fù)初試狀態(tài).(默認(rèn)情況下asp.net是通過SHA1算法而不是md5算法來生成散列,不過這個可以在machine.config里面配置machineKeyvalidation="MD5"即可),而viewstate加密就更簡單了,只要在machine.config里設(shè)置一下machineKeyvalidation="3DES"即可實(shí)現(xiàn)用des加密viewstate了.
使用方法
怎么在客戶端,存取ViewState?
應(yīng)用環(huán)境
一些與安全性無關(guān),數(shù)據(jù)量較小,需要長時間操作的參數(shù),應(yīng)該用ViewState存取。
在webgis中,地圖的各種相關(guān)狀態(tài),如zoom,center,layers,visibility等,用viewstate存取的話,就不存在session過期的問題,網(wǎng)頁可以永遠(yuǎn)使用,甚至可以下載保存,在進(jìn)行地圖請求,或iframe到第三方的應(yīng)用中。
Asp.net中的ViewState用法昨天看到一個文章,作者在自己的頁面中定義了幾個全局變量,類型是static,但是這樣的定義會存在問題,當(dāng)一個用戶訪問的時候不會有問題,但是當(dāng)大量用戶并發(fā)訪問系統(tǒng)的時候,頁面中的這些static類型的全局變量就會出現(xiàn)問題了,然后作者改用了Session變量保存以前由static類型全局變量紀(jì)錄的數(shù)據(jù),因?yàn)镾ession是狀態(tài)量,只是和某個訪問進(jìn)程相關(guān),這樣就不會出現(xiàn)由于static類型引起的問題了。但是這樣的話系統(tǒng)中的Session就太多了,我總認(rèn)為這樣不太好,雖然每個一個Session都有一個ID不會沖突。ASP.NET引入了ViewState,可以記錄同一個頁面的不同PostBack中的一些數(shù)據(jù)值。
所以我的解決方法是:使用例如ViewState["name"]這樣的形式記錄以前static的全局變量,這樣就可以避免這個問題了,因?yàn)槲业南到y(tǒng)是在局域網(wǎng)使用的,ViewState帶來的多余的數(shù)據(jù)量可以忽略不計(jì)了。asp.net ViewState用法:
ASP.NET中的ViewState是ASP.NET中用來保存WEB控件回傳時狀態(tài)值一種機(jī)制.在WEB窗體(FORM)的設(shè)置為runat="server",這個窗體(FORM)會被附加一個隱藏的屬性_VIEWSTATE._VIEWSTATE中存放了所有控件在ViewState中的狀態(tài)值.
ViewState是類Control中的一個域,其他所有控件通過繼承Control來獲得了ViewState功能.它的類型是system.Web.UI.StateBag,一個名稱/值的對象集合.
當(dāng)請求某個頁面時,ASP.NET把所有控件的狀態(tài)序列化成一個字符串,然后做為窗體的隱藏屬性送到客戶端.當(dāng)客戶端把頁面回傳時,ASP.NET分析回傳的窗體屬性,并賦給控件對應(yīng)的值.當(dāng)然這些全部是由ASP.NET負(fù)責(zé)的.
定義ViewState屬性
Public int PageCount
{
get{return(int)ViewState["PageCount"];}
set{ViewState["PageCount"]=value;}
}
使用ViewState的條件
如果要使用ViewState,則在ASPX頁面中必須有一個服務(wù)器端窗體標(biāo)記(<formrunat=server>).窗體字段是必需的,這樣包含ViewState信息的隱藏字段才能回傳給服務(wù)器.而且,該窗體還必須是服務(wù)器端的窗體,這樣在服務(wù)器上執(zhí)行該頁面時,ASP.NET頁面框架才能添加隱藏的字段.
Page的EnableViewState屬性值為true.
控件的EnableViewState屬性值為true.
提醒:
1.當(dāng)存在頁面回傳時,不需要維持控件的值就要把ViewState禁止.
2.ViewState的索引是大小寫敏感的.
3.ViewState不是跨頁面的.
4.為了能包存在ViewState中,對象必須是可流化或者定義了TypeConverter.
5.控件TextBox的TextMode屬性設(shè)置為PassWord時,它的狀態(tài)將不會被保存在ViewState中,這應(yīng)該是出于安全性的考慮.
6.在頁面沒有回傳或重定向或在回傳中轉(zhuǎn)到(transfer)其他頁面時不要使用ViewState.
7.在動態(tài)建立控件時要小心它的ViewState.
8.當(dāng)禁止一個程序的ViewState時,這個程序的所有頁面的ViewState也被禁止了.
9.只有當(dāng)頁面回傳自身時ViewState才是持續(xù)的.
設(shè)置ViewState
ViewState可以在控件,頁,程序,全局配置中設(shè)置.缺省情況下EnableViewState為true.如果要禁止所有頁面ViewState功能,可以在程序配置中把EnableViewState設(shè)為false.
本文關(guān)于:asp.netViewState用法
新聞熱點(diǎn)
疑難解答
圖片精選