1.QueryString是一種非常簡單的傳值方式,他可以將傳送的值顯示在瀏覽器的地址欄中。如果是傳遞一個或多個安全性要求不高或是結構簡單的數值時,可以使用這個方法。但是對於傳遞數組或對象的話,就不能用這個方法了。下面是一個例子:
private void Button1_Click(object sender, System.EventArgs e) { string s_url; s_url = "b.aspx?name=" + Label1.Text; Response.Redirect(s_url); } b.aspx中C#代碼 private void Page_Load(object sender, EventArgs e) { Label2.Text = Request.QueryString["name"]; }
query傳值又分類post ,get格式如:
//post請求 string name = Request["name"].toString(); string name =Request.Form.Get("name").toString(); //get請求 string name = Request.QueryString["name"].toString(); 但我發現 無論是否是post與get傳值都可用 string name = Request["name"].toString();
表單提交中get和post方式的區別歸納如下幾點:
1. get是從服務器上獲取數據,post是向服務器傳送數據。
2. get是把參數數據隊列加到提交表單的ACTION屬性所指的URL中,值和表單內各個字段一一對應,在URL中可以看到。post是通過HTTP post機制,將表單內各個字段與其內容放置在HTML HEADER內一起傳送到ACTION屬性所指的URL地址。用戶看不到這個過程。
3. 對於get方式,服務器端用Request.QueryString獲取變量的值,對於post方式,服務器端用Request.Form獲取提交的數據。
4. get傳送的數據量較小,不能大於2KB。post傳送的數據量較大,一般被默認為不受限制。但理論上,IIS4中最大量為80KB,IIS5中為100KB。
5. get安全性非常低,post安全性較高。
2. 使用Application 對象變量
Application對象的作用范圍是整個全局,也就是說對所有用戶都有效。其常用的方法用Lock和UnLock。
a.aspx的C#代碼 private void Button1_Click(object sender, System.EventArgs e) { Application["name"] = Label1.Text; Server.Transfer("b.aspx"); } b.aspx中C#代碼 private void Page_Load(object sender, EventArgs e) { string name; Application.Lock(); name = Application["name"].ToString(); Application.UnLock(); }
3. 使用Session變量
想必這個肯定是大家使用中最常見的用法了,其操作與Application類似,作用於用戶個人,所以,過量的存儲會導致服務器內存資源的耗盡。
a.aspx的C#代碼 private void Button1_Click(object sender, System.EventArgs e) { Session["name"] = Label.Text; } b.aspx中C#代碼 private void Page_Load(object sender, EventArgs e) { string name; name = Session["name"].ToString(); }
4. 使用Cookie對象變量
這個也是大家常使用的方法,與Session一樣,其是什對每一個用戶而言的,但是有個本質的區別,即Cookie是存放在客戶端的,而session是存放在服務器端的。而且Cookie的使用要配合ASP.NET內置對象Request來使用。
a.aspx的C#代碼 private void Button1_Click(object sender, System.EventArgs e) { HttpCookie cookie_name = new HttpCookie("name"); cookie_name.Value = Label1.Text; Reponse.AppendCookie(cookie_name); Server.Transfer("b.aspx"); } b.aspx中C#代碼 private void Page_Load(object sender, EventArgs e) { string name; name = Request.Cookie["name"].Value.ToString(); }
5. 使用Server.Transfer方法
這個才可以說是面象對象開發所使用的方法,其使用Server.Transfer方法把流程從當前頁面引導到另一個頁面中,新的頁面使用前一個頁面的應答流,所以這個方法是完全面象對象的,簡潔有效。
a.aspx的C#代碼 public string Name { get{ return Label1.Text;} } private void Button1_Click(object sender, System.EventArgs e) { Server.Transfer("b.aspx"); } b.aspx中C#代碼 private void Page_Load(object sender, EventArgs e) { a newWeb; //實例a窗體 newWeb = (source)Context.Handler; string name; name = newWeb.Name; }
下面介紹一下傳值缺點和優點
cookie
方式:將數據存在客戶端的經典方法。
缺點:安全性低、受客戶端設置限制、一個站點僅存20個cookie,每個容量4096字節。
Session
方式:將用戶數據存儲在服務端。
特點:asp.net中可以設置session的存儲方式、位置、SessionID的保存是否依賴cookie。
可以直接存儲對象。
缺點:asp.net中有失效的隱患
Cache
方式:將用戶數據存儲在服務端數據緩存中。
特點:可以大大提高效率。 可以直接存儲對象。
Appliction
方式: 將數據存儲於此,相當於全局變量。
特點:可以直接存儲對象。整個站點的共享數據
ViewState
方式:asp.net特有機制,用來恢復頁面狀態。
特點:將頁面各控件及其所存數據序列化存在name為_ViewState的隱藏域中。
缺點:存在HTML中,安全性較低。可以設置加密和驗證,但數據量會大增、效率有影響。
Static
方式: 將數據存於靜態變量中。
特點:利於提高效率。
缺點:若用不好會致使用戶或頁面間數據紊亂,造成極大的隱患。建議只賦值一次,絕對禁止為單個用戶而更改此值。
原文出處:http://www.111cn.net/net/net/41182.htm