1.使用session变量
使用这个方法是最常见的方法,在此中方式不仅可以把值传递到下一个页面,还可以交叉传递到多个页面,直至把Session变量的值removed后,变量才会消失。举例如下:
(1)创建一个web form
(2)在新建的web form中放置一个button1,在放置两个TextBox1,TextBox2
(3)为button按钮创建click事件
代码如下:
private void Button1_Click (object sender, System.EventArgs e)
{
Session["UserName"]=TextBox1.Text;
Session["Password"]=TextBox2.Text;
Response.Redirect("login.aspx");
}
(4)新建一个目标页面命名为login
(5)在webform2中放置两个Label1,Label2
在webform2的Page_Load中添加如下代码:
private void Page_Load (object sender, System.EventArgs e)
{
Label1.Text=Session["UserName"].ToString();
Label2.Text=Session["Password"].ToString();
Session.Remove("UserName"); //清除COOKIE
Session.Remove("Password"); //清除COOKIE
}
运行,即可看到传递后的结果了。
2.使用QueryString
Querystring是一种非常简单的传值方式,但是它的缺点就是会把要传送的值显示在浏览器的地址栏中,并且在此方法中不能够传递对象。如果你想传递一个安全性不是那么太重要或者是一个简单的数值时,这个方法是最合适的。举例如下:
(1)创建一个web form
(2)在新建的web form中放置一个button1,在放置两个TextBox1,TextBox2
(3)为button按钮创建click事件
代码如下:
private void Button1_Click (object sender, System.EventArgs e)
{
string url="webform2.aspx?UserName=" + TextBox1.Text + "&Password=" + TextBox2.Text;
Response.Redirect(url);
}
(4)新建一个目标页面命名为webform2
(5)在webform2中放置两个Label1,Label2
在webform2的Page_Load中添加如下代码:
private void Page_Load (object sender, System.EventArgs e)
{
Label1.Text=Request.QueryString["UserName"];
Label2.Text=Request.QueryString["Password"];
}
运行,即可看到传递后的结果了。
3.使用Server.Transfer
这个方法虽然有点麻烦,但是也是其中的一种。举例如下:
(1)创建一个web form
(2)在新建的web form中放置一个button1,在放置两个TextBox1,TextBox2
(3)为button按钮创建click事件
代码如下:
private void Button1_Click (object sender, System.EventArgs e)
{
Server.Transfer("webform2.aspx");
}
4、创建过程来返回TextBox1,TextBox2控件的值代码如下:
public string UserName
{
get
{
return TextBox1.Text;
}
}
public string Password
{
get
{
return TextBox2.Text;
}
}
(5)新建一个目标页面命名为webform2
在.aspx文件中声明对webform1的引用
<@%Reference Page="webform1.aspx"%>
(6)在webform2中放置两个Label1,Label2
在webform2的Page_Load中添加如下代码:
private void Page_Load (object sender, System.EventArgs e)
{
//创建原始窗体的实例
WebForm1 wf1;
//获得实例化的句柄
wf1=(WebForm1)Context.Handler;
Label1.Text=wf1.UserName;
Label2.Text=wf1.Password;
}
运行,即可看到传递后的结果了。
4.使用Cookie对象变量
与Session一样,是针对每一个用户而言的,但是有个本质的区别,即Cookie是存放在客户端的,而session是存放在服务器端的。而且Cookie的使用要配合ASP.NET内置对象Request来使用。
(1)创建一个web form
(2)在新建的web form中放置一个button1,在放置两个TextBox1
(3)为button按钮创建click事件
代码如下:
{
HttpCookie cookie_Name = new HttpCookie("UserName");
cookie_Name.Value = Label1.Text;
Response.AppendCookie(cookie_Name);
Server.Transfer("success.aspx");
}
success.aspx中代码如下:
private void Page_Load(object sender, EventArgs e)
{
string name= Request.Cookies["UserName"].Value.ToString();
}
5.使用Application对象变量
Application对象的作用范围是整个全局,也就是说对所有用户都有效。其常用的方法用Lock和UnLock。 void Button1_Click(object sender, System.EventArgs e)
{
Application["UserName"] = Label1.Text;
Server.Transfer("success.aspx");
}
success.aspx中的代码
{
string name;
Application.Lock();
name = Application["UserName"].ToString();
Application.UnLock();
}
注意地方:
server.Transfer与response.Redirect的作用都是重定向,server.Transfer与response.Redirect相比有两个优点、一个缺点:
优点:
一、它在服务器端直接重定向,不用像response.Redirect一样先与浏览器通信再重定向,效率高。
二、它可以传递上一个页面的提交值。比如:A页面提交值到B页面,B页面Transfer到C页面,C页面同样可以收到A页面提交的值。
缺点:
不能刷新页面,比如:A页面提交登录信息到B页面,B页面处理后Transfer再到A,A页面得不到刷新,指定了过期也不行。如果A、B页面不在同一个目录下,我们还会发现更多意想不到的结果,使用相对链接的图片、超链接的指向都改变了,造成这种原因是B页面读取A页面内容却以B页面的身份输出,所以路径改变了。