在两个ASP.NET页面之间传递变量【转】

ASP.NET提供了事件驱动编程模型,使开发者简化了应用程序的总体设计,但是这个也造成了它固有的一些问题,例如,在传统的ASP里,我们可以通过使用POST方法很容易地实现页面间传递变量,同样的事情,在使用事件驱动编程模型的ASP.NET就要麻烦一些,但是我们仍然有一些方法可以实现同样的功能。笔者在这里将包含使用querystring,session变量以及server.Transfer方法来实现页面间的变量传递。

使用QueryString 
使用QuerySting在页面间传递值已经是一种很老的机制了,这种方法的主要优点是实现起来非常简单,然而它的缺点是传递的值是会显示在浏览器的地址栏上的(不安全),同时又不能传递对象,但是在很多传递的值少而安全性要求不高的情况下,这个方法还是较多地被首选使用。

使用这种方法包括如下的步骤: 
a,使用控件创建web表单(form) 
b,创建可以返回表单的按钮和链接按钮 
c,在按钮或链接按钮的单击事件里创建一个保存URL的字符变量 
d,在保存的URL里添加QueryString参数 
e,使用Response.Redirect重定向到上面保存的URL 
下面的代码片断演示了如何实现这个方法: 
  源页面代码: 
private void Button1_Click 
(object sender, System.EventArgs e) 

 string url; 
 url="webform1.aspx?var1=" + TextBox1.Text + "&var2=" + TextBox2.Text; 
 Response.Redirect(url); 

 目标页面代码: 
 private void Page_Load 
(object sender, System.EventArgs e) 

 Label1.Text=Request.QueryString["var1"];

// Label1.Text=Request.QueryString["var1"] 也可以直写为 Label1.Text=Request["var1"]下面的语句也是一样可以简写 
 Label2.Text=Request.QueryString["var2"]; 

使用Session变量 
  使用Session变量是可以在页面间传递值的的另一种方式,在本例中我们把控件中的值存在Session变量中,然后在另一个页面中使用它,以不同页面间实现值传递的目的。但是,需要注意的是在Session变量存储过多的数据会消耗比较多的服务器资源,在使用session时应该慎重,当然了,我们也应该使用一些清理动作来去除一些不需要的session来降低资源的无谓消耗。使用Session变量传递值的一般步骤如下: 
a,在页面里添加必要的控件 
b,创建可以返回表单的按钮和链接按钮 
c,在按钮或链接按钮的单击事件里,把控件的值添加到session变量里 
d,使用Response.Redirect方法重定向到另一个页面 
e,在另一个页面提取session的值,在确定不需要使用该session时,要显式清除它

在开始使用前,首先看一下如何的使用SESSION,和ASP中相差不多 
写入SESSION变量:

C#: 
Session["username"])="aa";

VB:

Session("username")="aa" 
读取SESSINN变量:

C# 
string username= Session["username"]; 
VB:

dim username=Session("username")

下面的是一段使用session的程序代码 : 
   源页面代码: 
private void Button1_Click 
(object sender, System.EventArgs e) 

  Session["var1"]=TextBox1.Text; 
 Session["var2"]=TextBox2.Text; 
 Server.Transfer("webform1.aspx"); 

  目标页面代码: 
private void Page_Load 
(object sender, System.EventArgs e) 

 Label1.Text=Session["var1"].ToString(); 
 Label2.Text=Session["var2"].ToString(); 
 Session.Remove("var1"); 
 Session.Remove("var2"); 
}

使用Server.Transfer 
  这个方法相比上面介绍的方法稍微复杂一点,但在页面间变量传递中却是特别有用的,使用该方法你可以在另一个页面以对象属性的方式来存取显露的值,当然了,使用这种方法,你需要额外写一些代码以创建一些属性以便可以在另一个页面访问它,但是,这个方式带来的好处也是显而易见的。总体来说,使用这种方法是简洁的同时又是面向对象的。使用这种方法的整个过程如下: 
a,在页面里添加必要的控件 
b,创建返回值的Get属性过程 
c,创建可以返回表单的按钮和链接按钮 
d,在按钮单击事件处理程序中调用Server.Transfer方法转移到指定的页面 
e,在第二个页面中,我们就可以使用Context.Handler属性来获得前一个页面实例对象的引用,通过它,就可以使用存取前一个页面的控件的值了 
以下代码综合实现上述步骤过程的代码: 
  源页面代码: 
    把以下的代码添加到页面中 
   public string Var1 

 get 
 { 
 return TextBox1.Text; 
 } 
}

public string Var2 

 get 
 { 
 return TextBox2.Text; 
 } 

  然后调用Server.Transfer方法 
private void Button1_Click 
(object sender, System.EventArgs e) 

 Server.Transfer("webform1.aspx"); 

   目标页面代码: 
private void Page_Load 
(object sender, System.EventArgs e) 

 //create instance of source web form 
 WebForm1 wf1; 
 //get reference to current handler instance 
 wf1=(WebForm1)Context.Handler; 
 Label1.Text=wf1.Var1; 
 Label2.Text=wf1.Var2; 
}

后记:

笔者在上面使用不同的方法实现了ASP.NET页面间变量传递,这三种方法是:QueryString,Session和Server.Transfer,或许你还可以找到其他的办法来实现ASP.NET页面间变量传递,实际上你稍想点办法也可以将变量传递给页面自己(页面刷新特别是换页显示时传递新的页号等时比较常用)。

这里特别提下ruquest. QueryString 中的request对象实际上操作system.web 命名空间中的类httprequest。当客户发出请求执行asp.net时,CLR会将客户端请求信息包装在Request对象中。这些请求信息包括请求报头、客户端基本信息(浏览器信息、浏览器版本号、用户所用的语言、编码方式等)、请求方法(post、get)、参数名、参数值等。Request对象的调用方法为:

Request.collection[“variable”]

其中collection包括QueryStrin、Form、Cookies、ServerVariables四种集合,我们上面曾提到可以将Request.QueryString["var1"]写为Request["var1"]看起来比较简洁,但这样作其实不是一种好的方法,因为省掉collection选项后,Request会按照QueryString、Form、Cookies、ServerVariables的顺序进行搜索直到发现“variable”所指的关键字并返回其值,没有找到则返回(null)。因此为了提供程序的执行效率,最好还是指定collection,过多地搜索会影响程序执行的效率。置于Cookies、ServerVariables等我将在以后的文章详细说明。

时间: 2024-10-09 02:07:51

在两个ASP.NET页面之间传递变量【转】的相关文章

ASP.NET页面之间传递值的几种方式

页面传值是学习asp.net初期都会面临的一个问题,总的来说有页面传值.存储对象传值.ajax.类.model.表单等.但是一般来说,常用的较简单有QueryString,Session,Cookies,Application,Server.Transfer 一.QueryString QueryString是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中.如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法.但是对于传递数组或对象的话,就不能用这个方法了.

ASP.NET页面之间传递值(1):QueryString

QueryString是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中.如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法.但是对于传递数组或对象的话,就不能用这个方法了. 这种方法的优点:1.使用简单,对于安全性要求不高时传递数字或是文本值非常有效. 这种方法的缺点:1.缺乏安全性,由于它的值暴露在浏览器的URL地址中的. 2.不能传递对象. 使用方法:1.在源页面的代码中用需要传递的名称和值构造URL地址. 2.在源页面的代码用Response.Redi

ASP.NET页面之间传递值(4):Server.Transfer

这个才可以说是面象对象开发所使用的方法,其使用Server.Transfer方法把流程从当前页面引导到另一个页面中,新的页面使用前一个页面的应答流,所以这个方法是完全面象对象的,简洁有效. Server.Transfer是从当前的ASPX页面转到新的ASPX页面,服务器端执行新页并输出,在新页面中通过 Context.Handler来获得前一个页面传递的各种数据类型的值.表单数据.QueryString.由于重定向完全在服务器端完成,所以客户端 浏览器中的URL地址是不会改变的.调用Server

ASP.NET页面之间传递值(2):Session

想必这个肯定是大家使用中最常见的用法了,其操作与Application类似,作用于用户个人,所以,过量的存储会导致服务器内存资源的耗尽. 优点:1.使用简单,不仅能传递简单数据类型,还能传递对象. 2.数据量大小是不限制的. 缺点:1.在Session变量存储大量的数据会消耗较多的服务器资源. 2.容易丢失. 使用方法:1.在源页面的代码中创建你需要传递的名称和值构造Session变量:Session["Name"]="Value(Or Object)"; 2.在目

ASP.NET页面之间传递值(5):Application

Application对象的作用范围是整个全局,也就是说对所有用户都有效.它在整个应用程序生命周期中都是有效的,类似于使用全局变量一样,所 以可以在不同页面中对它进行存取.它和Session变量的区别在于,前者是所有的用户共用的全局变量,后者是各个用户独有的全局变量. 可能有人会问,既然所有用户都可以使用application变量,那他可以用在什么场合呢?这里举个例子:网站访问数.多个请求访问时都可以对它进行操作. 优点:1.使用简单,消耗较少的服务器资源. 2.不仅能传递简单数据,还能传递对象

ASP.NET页面之间传递值(3):Cookie

这个也是大家常使用的方法,Cookie用于在用户浏览器上存储小块的信息,保存用户的相关信息,比如用户访问某网站时用户的ID,用户的偏好等, 用户下次访问就可以通过检索获得以前的信息.所以Cookie也可以在页面间传递值.Cookie通过HTTP头在浏览器和服务器之间来回传递的. Cookie只能包含字符串的值,如果想在Cookie存储整数值,那么需要先转换为字符串的形式. 与Session一样,其是什对每一个用户而言的,但是有个本质的区别,即Cookie是存放在客户端的,而session是存放在

ASP.NET页面之间传递值的几种方式 (转)

页面传值是学习asp.net初期都会面临的一个问题,总的来说有页面传值.存储对象传值.ajax.类.model.表单等.但是一般来说,常用的较简单有QueryString,Session,Cookies,Application,Server.Transfer. 一.QueryString QueryString是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中.如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法.但是对于传递数组或对象的话,就不能用这个方法了.

[转载]ASP.NET页面之间传递值的几种方式

页面传值是学习asp.net初期都会面临的一个问题,总的来说有页面传值.存储对象传值.ajax.类.model.表单等.但是一般来说,常用的较简单有QueryString,Session,Cookies,Application,Server.Transfer. 一.QueryString QueryString是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中.如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法.但是对于传递数组或对象的话,就不能用这个方法了.

ASP.NET 页面之间传递值的几种方式

1.使用QueryString,  如....?id=1; response. Redirect().... 2.使用Session变量 3.使用Server.Transfer4.Application 5.<input type="hidden"></input> 6.数据库 使用QueryString 使用QuerySting在页面间传递值已经是一种很老的机制了,这种方法的主要优点是实现起来非常简单,然而它的缺点是传递的值是会显示在浏 览器的地址栏上的(不安