頁面傳值是學習asp.net初期都會面臨的一個問題,總的來說有頁面傳值、儲存物件傳值、ajax、類、model、表單等。但是一般來說,常用的較簡單有QueryString,Session,Cookies,Application,Server.Transfer。
一、QueryString
QueryString是一種非常簡單的傳值方式,他可以將傳送的值顯示在瀏覽器的位址列中。如果是傳遞一個或多個安全性要求不高或是結構簡單的數值時,可以使用這個方法。但是對於傳遞陣列或物件的話,就不能用這個方法了。
這種方法的優點:1.使用簡單,對於安全性要求不高時傳遞數字或是文字值非常有效。
這種方法的缺點:1.缺乏安全性,由於它的值暴露在瀏覽器的URL地址中的。
2.不能傳遞物件。
使用方法:1.在源頁面的程式碼中用需要傳遞的名稱和值構造URL地址。
2.在源頁面的程式碼用Response.Redirect(URL);重定向到上面的URL地址中。
3.在目的頁面的程式碼使用Request.QueryString["name"];取出URL地址中傳遞的值。
例子:(1)a.aspx
private void Button1_Click(object sender, System.EventArgs e)
{
string s_url;
s_url = "b.aspx?name=" + Label1.Text;
Response.Redirect(s_url);
}
(2)b.aspx
private void Page_Load(object sender, EventArgs e)
Label2.Text = Request.QueryString["name"];
二、Session
想必這個肯定是大家使用中最常見的用法了,其操作與Application類似,作用於使用者個人,所以,過量的儲存會導致伺服器記憶體資源的耗盡。
優點:1.使用簡單,不僅能傳遞簡單資料型別,還能傳遞物件。
2.資料量大小是不限制的。
缺點:1.在Session變數儲存大量的資料會消耗較多的伺服器資源。
2.容易丟失。
使用方法:1.在源頁面的程式碼中建立你需要傳遞的名稱和值構造Session變數:Session["Name"]="Value(Or Object)";
2.在目的頁面的程式碼使用Session變數取出傳遞的值。Result = Session["Nmae"]
注意:session不用時可以銷燬它,銷燬的方法是:清除一個:Session.Remove("session名");
清除所有:Session.Clear();
Session["name"] = Label.Text;
string name;
name = Session["name"].ToString();
三、Cookie
這個也是大家常使用的方法,Cookie用於在使用者瀏覽器上儲存小塊的資訊,儲存使用者的相關資訊,比如使用者訪問某網站時使用者的ID,使用者的偏好等,使用者下次訪問就可以透過檢索獲得以前的資訊。所以Cookie也可以在頁面間傳遞值。Cookie透過HTTP頭在瀏覽器和伺服器之間來回傳遞的。Cookie只能包含字串的值,如果想在Cookie儲存整數值,那麼需要先轉換為字串的形式。
與Session一樣,其是什對每一個使用者而言的,但是有個本質的區別,即Cookie是存放在客戶端的,而session是存放在伺服器端的。而且Cookie的使用要配合ASP.NET內建物件Request來使用。
優點:1.使用簡單,是保持使用者狀態的一種非常常用的方法。比如在購物網站中使用者跨多個頁面表單時可以用它來保持使用者狀態。
缺點:1.常常被人認為用來收集使用者隱私而遭到批評。
2.安全性不高,容易偽造。
使用方法:1.在源頁面的程式碼中建立你需要傳遞的名稱和值構造Cookie物件:
HttpCookie objCookie = new HttpCookie("myCookie","Hello,Cookie!");
Response.Cookies.Add(cookie);
2.在目的頁面的程式碼使用Cookie物件取出傳遞的值:Result = Request.Cookies[ "myCookie" ].Value;
Response.Cookies.Add(objCookie);
string myName1Value;
myName1Value = Request.Cookies[ "myCookie" ].Value;
頁面傳值是學習asp.net初期都會面臨的一個問題,總的來說有頁面傳值、儲存物件傳值、ajax、類、model、表單等。但是一般來說,常用的較簡單有QueryString,Session,Cookies,Application,Server.Transfer。
一、QueryString
QueryString是一種非常簡單的傳值方式,他可以將傳送的值顯示在瀏覽器的位址列中。如果是傳遞一個或多個安全性要求不高或是結構簡單的數值時,可以使用這個方法。但是對於傳遞陣列或物件的話,就不能用這個方法了。
這種方法的優點:1.使用簡單,對於安全性要求不高時傳遞數字或是文字值非常有效。
這種方法的缺點:1.缺乏安全性,由於它的值暴露在瀏覽器的URL地址中的。
2.不能傳遞物件。
使用方法:1.在源頁面的程式碼中用需要傳遞的名稱和值構造URL地址。
2.在源頁面的程式碼用Response.Redirect(URL);重定向到上面的URL地址中。
3.在目的頁面的程式碼使用Request.QueryString["name"];取出URL地址中傳遞的值。
例子:(1)a.aspx
private void Button1_Click(object sender, System.EventArgs e)
{
string s_url;
s_url = "b.aspx?name=" + Label1.Text;
Response.Redirect(s_url);
}
(2)b.aspx
private void Page_Load(object sender, EventArgs e)
{
Label2.Text = Request.QueryString["name"];
}
二、Session
想必這個肯定是大家使用中最常見的用法了,其操作與Application類似,作用於使用者個人,所以,過量的儲存會導致伺服器記憶體資源的耗盡。
優點:1.使用簡單,不僅能傳遞簡單資料型別,還能傳遞物件。
2.資料量大小是不限制的。
缺點:1.在Session變數儲存大量的資料會消耗較多的伺服器資源。
2.容易丟失。
使用方法:1.在源頁面的程式碼中建立你需要傳遞的名稱和值構造Session變數:Session["Name"]="Value(Or Object)";
2.在目的頁面的程式碼使用Session變數取出傳遞的值。Result = Session["Nmae"]
注意:session不用時可以銷燬它,銷燬的方法是:清除一個:Session.Remove("session名");
清除所有:Session.Clear();
例子:(1)a.aspx
private void Button1_Click(object sender, System.EventArgs e)
{
Session["name"] = Label.Text;
}
(2)b.aspx
private void Page_Load(object sender, EventArgs e)
{
string name;
name = Session["name"].ToString();
}
三、Cookie
這個也是大家常使用的方法,Cookie用於在使用者瀏覽器上儲存小塊的資訊,儲存使用者的相關資訊,比如使用者訪問某網站時使用者的ID,使用者的偏好等,使用者下次訪問就可以透過檢索獲得以前的資訊。所以Cookie也可以在頁面間傳遞值。Cookie透過HTTP頭在瀏覽器和伺服器之間來回傳遞的。Cookie只能包含字串的值,如果想在Cookie儲存整數值,那麼需要先轉換為字串的形式。
與Session一樣,其是什對每一個使用者而言的,但是有個本質的區別,即Cookie是存放在客戶端的,而session是存放在伺服器端的。而且Cookie的使用要配合ASP.NET內建物件Request來使用。
優點:1.使用簡單,是保持使用者狀態的一種非常常用的方法。比如在購物網站中使用者跨多個頁面表單時可以用它來保持使用者狀態。
缺點:1.常常被人認為用來收集使用者隱私而遭到批評。
2.安全性不高,容易偽造。
使用方法:1.在源頁面的程式碼中建立你需要傳遞的名稱和值構造Cookie物件:
HttpCookie objCookie = new HttpCookie("myCookie","Hello,Cookie!");
Response.Cookies.Add(cookie);
2.在目的頁面的程式碼使用Cookie物件取出傳遞的值:Result = Request.Cookies[ "myCookie" ].Value;
例子:(1)a.aspx
private void Button1_Click(object sender, System.EventArgs e)
{
HttpCookie objCookie = new HttpCookie("myCookie","Hello,Cookie!");
Response.Cookies.Add(objCookie);
}
(2)b.aspx
string myName1Value;
myName1Value = Request.Cookies[ "myCookie" ].Value;