.net C#中頁面之間傳值傳參的六種方法

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

發佈了14 篇原創文章 · 獲贊 25 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章