1、QueryString
當頁面上form按照get的方式向頁面發(fā)送請求數(shù)據(jù)的時候,web server會將請求數(shù)據(jù)放入
一個QEURY_STRING的環(huán)境變量中,然后通過QeueryString方法從這個變量中獲取相應(yīng)的參數(shù)。
例如:
發(fā)送參數(shù)頁面Test1.aspx 按鈕單擊代碼:
string url = "Test2.aspx?id="+ txtId.Text;
Response.Redirect(url);
接收參數(shù)頁面 Test2.aspx
后臺代碼獲取:string id=Request.QueryString["id"];
優(yōu)點:使用比較簡單
缺點:安全性低,參數(shù)直接暴露在url上,并且不能傳遞對象。
2、Session
把需要傳的值放在Session變量中,然后在另外一個變量中使用它,session存放在服務(wù)器端,
在Session變量中存儲過多的變量,會消耗較多的服務(wù)器資源,所以要及時清理不需要的Session變量。
優(yōu)點:能傳遞復(fù)雜對象,數(shù)據(jù)量大小不限制
缺點:作為全局變量,容易誤操作。
用法:
Session["id"]= txtId.Text;
在接收頁面調(diào)用:string id=Session["id"].ToString();
3、Application
Application在整個應(yīng)用程序生命周期都是有效的,類似于使用全局變量,是所有的用戶
共用的全局變量,session是單個用戶獨有的全局變量,Application一般用于記錄用戶
信息、統(tǒng)計在線人數(shù)等。
用法:
Application.Lock();
Application["id"]= txtId.Text;
Server.Transfer("Test2.aspx");
Application.UnLock();
在接收頁面調(diào)用:string id=Application["id"].ToString();
4、Cookie
Cookie主要用于客戶端保存用戶的信息,比如登錄信息,它通過HTTP頭傳遞信息,只能
包含字符串的值,通過Request對象的Cookie集合可以獲得瀏覽器所有的Cookie。
優(yōu)點:使用簡單,可以減輕服務(wù)器的負擔(dān),通過Cookie來保存用戶的登錄狀態(tài),實現(xiàn)記住
用戶登錄的功能。
缺點:被認為用來收集用戶隱私而遭到批評,也可能被別人篡改、偽造登錄信息。
用法:
Test1.aspx 按鈕單擊代碼:
HttpCookie name =new HttpCookie("name1");
HttpCookieage = new HttpCookie("age1");
name.Value = txtName.Text;
age.Value = txtAge.Text;
Response.Cookies.Add(name);
Response.Cookies.Add(age);
Server.Transfer("Test2.aspx");
Test2.aspx 按鈕單擊代碼:
TextBox1.Text = "姓名是:" +Request.Cookies["name1"].Value.ToString() + "年齡是:" +Request.Cookies["age1"].Value.ToString();
5、Server.Transfer
Server.Transfer 是一個很奇特的方法。當使用 Server.Transfer 方法重定向頁面時,
雖然頁面也會被重定向至指定頁,但是并不會在瀏覽器的URL上體現(xiàn)出來,并且若重定
向的頁面后有參數(shù),也不會顯示在瀏覽器的URL上。
優(yōu)點:直接在服務(wù)器端重定向,使用簡單方便,減少了客戶端對服務(wù)器端提出請求;
缺點:客戶端瀏覽器中的URL地址是不改變,會導(dǎo)致在新的頁面可能出現(xiàn)一些意想不到的問題。
比如如果源頁面和目的頁面不在同一個虛擬目錄或其子目錄下,那么使用相對路徑的
圖片、超鏈接都會導(dǎo)致錯誤的指向。可以傳遞各種數(shù)據(jù)類型的值和控件的值。
來源:我的公眾號