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
(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();
}