QueryString是一種很是簡單的傳值方式,他能夠將傳送的值顯示在瀏覽器的地址欄中。若是是傳遞一個或多個安全性要求不高或是結構簡單的數值時,可使用這個方法。可是對於傳遞數組或對象的話,就不能用這個方法了。下面是一個例子:數組
a.aspx的C#代碼瀏覽器
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"]; }服務器
Application對象的做用範圍是整個全局,也就是說對全部用戶都有效。其經常使用的方法用Lock和UnLock。cookie
a.aspx的C#代碼session
private void Button1_Click(object sender, System.EventArgs e) { Application["name"] = Label1.Text; Server.Transfer("b.aspx"); }url
b.aspx中C#代碼對象
private void Page_Load(object sender, EventArgs e) { string name; Application.Lock(); name = Application["name"].ToString(); Application.UnLock(); }內存
想必這個確定是你們使用中最多見的用法了,其操做與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(); }
這個也是你們常使用的方法,與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(); }
這個才能夠說是面象對象開發所使用的方法,其使用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; }