页面传值是学习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.在源页面的代码中