無狀態(tài)Http
無狀態(tài)的根本原因是:瀏覽器和服務器使用Socket通信,服務器將請求結(jié)果返回給瀏覽器后,會關(guān)閉當前Socket連接。而且服務器會在處理頁面完畢后銷毀頁面對象。
應用層面的原因是:瀏覽器和服務器之間通信都遵守HTTP協(xié)議。
一個瀏覽者發(fā)出的請求都是由實現(xiàn)了IHttpHandler接口的對象進行響應,由于下次訪問不一定還是上次那個對象進行響應,上次響應完畢對象可能已經(jīng)被銷毀了,寫的類變量值早就不存在了,因此不能將狀態(tài)信息保存到類變量中。
編寫一個ashx
對網(wǎng)站造成的影響:如果用戶錄入了一些信息,當跳轉(zhuǎn)到下一個頁面時,數(shù)據(jù)丟失,再也不能獲得那些數(shù)據(jù)。
如果要知道上一次的狀態(tài)信息,我們就得把這個狀態(tài)信息記錄在某個地方:
a.服務器端Session
b.瀏覽器端Cookie
c. 表單元素中—如:隱藏域input type=“hidden”/>(Http報文)ViewState
四個重要的
ViewState:
ASP.NET 的 .aspx頁面特有,頁面級的;
就是在頁面上的一個隱藏域中保存客戶端單獨使用的數(shù)據(jù)的一種方式;
服務器端控件的值都自動保存在ViewState中;
Cookie:
HTTP協(xié)議下的一種方式,通過該方式,服務器或腳本能夠在客戶機上維護狀態(tài)信息;
就是在客戶端保存客戶端單獨使用的數(shù)據(jù)的一種方式;
就像你的病歷本一樣,醫(yī)院直接給你帶回家;
Session:和.Net提供的輔助進程相關(guān)。
在服務器端保存客戶端單獨使用的數(shù)據(jù)的一種方式;
就像銀行賬戶,錢都存在銀行里,你就拿一張銀行卡【所謂的SessionId】回家(寫入客戶端的Cookie中);
Application:
在服務器端保存共享數(shù)據(jù)的一種方式;
就像銀行的單人公共衛(wèi)生間,誰進去都行,但一次去一個,進去了就鎖上門,出來再把鎖打開;
ViewState(頁面級)
使用方式: 作用域---頁面級
保存數(shù)據(jù)方式:
使用ViewState的前提:
頁面上必須有一個服務器端窗體標記(form runat=“server”>)
服務器在接收到用戶請求一個頁面后,會自動在請求報文中找看是否包含__VIEWSTATE的隱藏域,如果有,則將中間的值解碼后添加到頁面的ViewState屬性中。
服務器在輸出的時候,也會自動的將ViewState中的值添加到表單里名叫__VIEWSTATE的隱藏域中。
VIEWSTATE適用于同一個頁面在不關(guān)閉的情況下多次與服務器交互
跨頁面提交的__VIEWSTATE不會被目標頁面裝入頁面的ViewState屬性中
添加runat=server生成html頁面源碼如下
未添加如下:
__VIEWSTATE隱藏域生成的原理
補充:
禁用ViewState的方法,禁用單個控件的ViewState設定enableviewstate=false。禁用整個頁面的,在aspx的Page指令區(qū)加上EnableViewState="false" 。內(nèi)網(wǎng)系統(tǒng)、互聯(lián)網(wǎng)的后臺可以盡情的用ViewState。但互聯(lián)網(wǎng)前臺就不要使用了【注:禁用也只是不保存服務端控件屬性和值但隱藏域還是存在的】
WebForm的IsPostBack內(nèi)部實現(xiàn) 就是對頁面或者get傳參中是否含有__ViewState這一參數(shù)名稱進行判斷返回bool值
證實: