Cookies QueryString Application Session
1、利用cookies保持客戶端信息
.NET System Web 控件名稱以下三個類,可以使用它們來處理客戶端的Cookies
1、HttpCookie:提供一個建立和操作獨立HTTPcookies的安全類型的方式
2、HttpResponse:Cookies屬性允許客戶端cookies被操作
3、HttpRequest:Cookies屬性允許訪問客戶端操作的cookies
HttpResponse和HttpRequest對象的Cookies屬性將返回一個HttpCookieCollection對象,它可以將單獨的cookies添加到集合(collection)中,
以及從集合(collection)獲得一個單獨cookies。
HttpCookie類針對於客戶存儲而建立的單獨的cookies。一旦HttpCookie對象被建立,可以將其添加到HttpResponse對象的Cookies屬性中。同樣的,
可以通過HttpResponse對象訪問現有的cookies。HttpCookies類的共有屬性如下:
1)Domain:獲得或設置與cookie有關的域名,可用於限制特定區域的cookie訪問
2)Expires:獲得或設置cookie的終止日期和時間,可以將其設置為一個過去的日期以自動禁止或者刪除cookie
3)Names:獲得或設置cookie的名稱
4)Path:獲得或設置cookie的虛擬路徑。這一屬性允許限制cookie的范圍,也就是說,訪問cookie只能限制於一個特定的文件夾或路徑。
設置這一屬性限制為只能訪問特定路徑和該路徑下的所有文件
5)Secure:發信號以表示是否使用SecureSocketsLayer(SSL)來發送cookie值
6)Value:獲得或設置一個單獨的cookie值
7)Values:返回包含在cookie中的key/value的一個集合
每一個Cookie都是從Cookies中獲得的,就是說Cookie是通過索引器的方式獲得的。
利用Response、Request對象讀寫,語法如下:
//保存信息到Cookie中
Response.Cookies["Cookie的名字"].value=變量的值;
//讀取Cookie
Object 變量名=Request.Cookies["Cookie的名字"].value;
Cookie屬於HttpCookie,所以它的語法也可以寫成如下形式:
//鍵值對的方式保存信息
HttpCookie hCookie = new HttpCookie("Cookie的名字",值);
//保存Cookie到Cookies中
Response.Cookies.Add(hCookie);
例:
//保存信息到Cookie中
protected void btnWrite_Click(object sender, EventArgs e)
{
Response.Cookies["firstcookie"].Value = textbox1.Text.Trim();
Response.Cookies["secondcookie"].Value = textbox2.Text.Trim();
//Response.Cookies["firstcookie"].Expires = DateTime.Now.AddDays(1);
// Response.Cookies["secondcookie"].Value = DateTime.Now.ToString();
}
//獲取Cookie中的信息
protected void btnRead_Click(object sender, EventArgs e)
{
textbox1.Text= Request.Cookies["firstcookie"].Value;
textbox2.Text = Request.Cookies["secondcookie"].Value;
}
2、QueryString
當使用表單的get方式提交數據時,表單中的數據被保存在Request對象的Querystring集合中。除了讀取表單對象傳遞的參數外,Querystring集合還可以通過讀取HTTP查詢字符串中的參數值來傳遞參數。使用Querystring集合來傳遞數據的語法格式為:
Request.Querystring(變量名)[(索引值)|.變量的個數]
其中各個參數的含義如下:
1)變量名為在HTTP查詢字符串中指定要檢索的變量名稱
2)索引值用於檢索多個變量值中的某一個
3)HTTP查詢字符串中的變量值由問號(?)後面的值指定
用QueryString在頁面間傳遞值得具體過程有以下三步:
(1)在源頁面的代碼中用需要傳遞的名稱和值構造URL地址
(2)在源頁面的代碼中用Request.Redirect(URL);重定向到上面的URL地址中
(3)在目的頁面的代碼中用Request.QueryString["name"];取出URL地址中傳遞的值
例:
protected void btnSendMessage_Click(object sender, EventArgs e)
{
//第一步
string urlAddress;
urlAddress = "ReadCookie.aspx?name1=" +
textbox1.Text.ToString() + "&" +
"name2=" + textbox2.Text.ToString() + "&" +
"name3=" + textbox3.Text.ToString();
//第二步
Response.Redirect(urlAddress);
}
protected void btnRead_Click(object sender, EventArgs e)
{
//第三步
textbox1.Text = Request.QueryString["name1"];
textbox2.Text = Request.QueryString["name2"];
textbox3.Text = Request.QueryString["name3"];
}
使用QueryString在頁面間傳遞值的優缺點:
優點:
使用簡單,對於安全性要求不高時傳遞數字或文本值非常有效
缺點:
1)缺乏安全性,是因為它的值暴露在浏覽器的URL地址中
2)不能傳遞對象
3、Application
Application變量在整個應用程序生命周期中都是有效的,類似於使用全局變量,所以可以在不同頁面中對它進行存取。它和Session變量的區別在於,前者是所有的用戶公用的全局變量,後者是各個用戶獨有的全局變量。
Application變量的使用方法如下:
1)在源頁面的代碼中創建需要傳遞的名稱和值構造Application變量,如:
Application["Name"]="Value(Or Object)";
2)在目的頁面的代碼使用Application變量取出傳遞的值,如:
Result=Application["Name"];
例:
protected void btnSendMessage_Click(object sender, EventArgs e)
{
Application["name1"] = textbox1.Text;
Application["name2"] = textbox2.Text;
Application["name3"] = textbox3.Text;
Response.Redirect("ReadCookie.aspx");
}
protected void btnRead_Click(object sender, EventArgs e)
{
textbox1.Text = Application["name1"].ToString();
textbox2.Text = Application["name2"].ToString();
textbox3.Text = Application["name3"].ToString();
}
使用Application進行頁面傳值的優缺點:
優點:
(1)使用簡單,消耗較少的服務器資源
(2)不僅能傳遞簡單的數據類型,還能傳遞對象
(3)數據量大小是不受限制的
缺點:
(1)作為全局變量容易被誤操作
4、Session
Session變量和Application變量非常類似,它們的區別在Application變量中提到了。它的使用方法如下:、
1)在源頁面的代碼中創建需要傳遞的名稱和值構造Session變量,如:
Session["name"]="Value(Or Object)";
2)在目的頁面的代碼中使用Session變量取出傳遞的值,如:
Result=Session["name"];
使用Session進行頁面傳值的優缺點:
優點:
(1)使用簡單,不僅能傳遞簡單的數據類型,還能傳遞對象
(2)數據量大小是不受限制的
缺點:
(1)在Session變量存儲大量的數據會消耗較多的服務器資源