ASP.NET中页面之间传递值的几种方式整理
程序员文章站
2024-03-06 23:14:44
但是一般来说,常用的较简单有querystring,session,cookies,application,server.transfer。一、querystring ...
但是一般来说,常用的较简单有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.在源页面的代码中创建你需要传递的名称和值构造cookie对象:
httpcookie objcookie = new httpcookie("mycookie","hello,cookie!");
response.cookies.add(cookie);
2.在目的页面的代码使用cookie对象取出传递的值:result = request.cookies[ "mycookie" ].value;
例子:(1)a.aspx
private void button1_click(object sender, system.eventargs e)
{
httpcookie objcookie = new httpcookie("mycookie","hello,cookie!");
response.cookies.add(objcookie);
}
(2)b.aspx
string myname1value;
myname1value = request.cookies[ "mycookie" ].value;
四、application
application对象的作用范围是整个全局,也就是说对所有用户都有效。它在整个应用程序生命周期中都是有效的,类似于使用全局变量一样,所以可以在不同页面中对它进行存取。它和session变量的区别在于,前者是所有的用户共用的全局变量,后者是各个用户独有的全局变量。
可能有人会问,既然所有用户都可以使用application变量,那他可以用在什么场合呢?这里举个例子:网站访问数。多个请求访问时都可以对它进行操作。
优点:1.使用简单,消耗较少的服务器资源。
2.不仅能传递简单数据,还能传递对象。
3.数据量大小是不限制的。
缺点:1.作为全局变量容易被误操作。所以单个用户使用的变量一般不能用application。
使用方法:1.在源页面的代码中创建你需要传递的名称和值构造application变量:application["nmae"]="value(or object)";
2.在目的页面的代码使用application变量取出传递的值。result = application["nmae"]
注意:常用lock和unlock方法用来锁定和解锁,为了防止并发修改。
例子:(1)a.aspx
private void button1_click(object sender, system.eventargs e)
{
application["name"] = label1.text;
}
(2)b.aspx
private void page_load(object sender, eventargs e)
{
string name;
application.lock();
name = application["name"].tostring();
application.unlock();
}
五、server.transfer
这个才可以说是面象对象开发所使用的方法,其使用server.transfer方法把流程从当前页面引导到另一个页面中,新的页面使用前一个页面的应答流,所以这个方法是完全面象对象的,简洁有效。
server.transfer是从当前的aspx页面转到新的aspx页面,服务器端执行新页并输出,在新页面中通过context.handler来获得前一个页面传递的各种数据类型的值、表单数据、querystring.由于重定向完全在服务器端完成,所以客户端浏览器中的url地址是不会改变的。调用server.transfer时,当前的aspx页面终止执行,执行流程转入另一个aspx页面,但新的aspx页面仍使用前一aspx页面创建的应答流。
ps:比较server.transfer和response.redirect的区别。
(1)server.transfer在服务器端完成,所以客户端浏览器中的url地址是不会改变的;response.redirect是客户端完成,向服务器端提出新的页面处理请求,所以客户端浏览器中的url地址是会改变的。
(2)server.transfer在服务器端完成,不需要客户端提出请求,减少了客户端对服务器端提出请求。[2]
(3)server.transfer只能够转跳到本地虚拟目录指定的页面,也就是工程项目中的页面,而response.redirect则十分灵活,可以跳转到任何url地址。
(4)server.transfer可以将前一个页面的各种类型的值传到新的页面;response.redirect则只能借助url中带参数或是结合上面四种办法把各种类型的值传到新的页面。
优点:1.直接在服务器端重定向,使用简单方便,减少了客户端对服务器端提出请求。
2.可以传递各种数据类型的值和控件的值。
缺点:1.客户端浏览器中的url地址是不改变,会导致在新的页面可能出现一些意想不到的问题。比如如果源页面和目的页面不在同一个虚拟目录或其子目录下,那么使用相对路径的图片、超链接都会导致错误的指向。
使用方法:1.在源页面的代码中,使用page类的server.transfer跳到另一个页面传递页面数据:server.transfer("b.aspx","false")。
2.在目的页面中,使用context.handler来接收数据:formerpage formerpage = (formerpage)context.handler; 然后用formerpage的属性和方法来获取前一个页面的值,或者直接用context.items["myparameter "]
例子:(1)a.aspx
public string name
{
get{ return label1.text;}
}
private void button1_click(object sender, system.eventargs e)
{
server.transfer("b.aspx");
}
(2)b.aspx
private void page_load(object sender, eventargs e)
{
a newweb; //实例a窗体
newweb = (source)context.handler;
string name;
name = newweb.name;
}
以上就是常用的几种页面间传值的方法,我一般使用session和querystring来传值,少数情况会使用到cookie。本篇文章仅仅是介绍这几种方法的使用方法,内部原理没有过多的解释,关于session的存储方式请参见:
一、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.在源页面的代码中创建你需要传递的名称和值构造cookie对象:
httpcookie objcookie = new httpcookie("mycookie","hello,cookie!");
response.cookies.add(cookie);
2.在目的页面的代码使用cookie对象取出传递的值:result = request.cookies[ "mycookie" ].value;
例子:(1)a.aspx
复制代码 代码如下:
private void button1_click(object sender, system.eventargs e)
{
httpcookie objcookie = new httpcookie("mycookie","hello,cookie!");
response.cookies.add(objcookie);
}
(2)b.aspx
复制代码 代码如下:
string myname1value;
myname1value = request.cookies[ "mycookie" ].value;
四、application
application对象的作用范围是整个全局,也就是说对所有用户都有效。它在整个应用程序生命周期中都是有效的,类似于使用全局变量一样,所以可以在不同页面中对它进行存取。它和session变量的区别在于,前者是所有的用户共用的全局变量,后者是各个用户独有的全局变量。
可能有人会问,既然所有用户都可以使用application变量,那他可以用在什么场合呢?这里举个例子:网站访问数。多个请求访问时都可以对它进行操作。
优点:1.使用简单,消耗较少的服务器资源。
2.不仅能传递简单数据,还能传递对象。
3.数据量大小是不限制的。
缺点:1.作为全局变量容易被误操作。所以单个用户使用的变量一般不能用application。
使用方法:1.在源页面的代码中创建你需要传递的名称和值构造application变量:application["nmae"]="value(or object)";
2.在目的页面的代码使用application变量取出传递的值。result = application["nmae"]
注意:常用lock和unlock方法用来锁定和解锁,为了防止并发修改。
例子:(1)a.aspx
复制代码 代码如下:
private void button1_click(object sender, system.eventargs e)
{
application["name"] = label1.text;
}
(2)b.aspx
复制代码 代码如下:
private void page_load(object sender, eventargs e)
{
string name;
application.lock();
name = application["name"].tostring();
application.unlock();
}
五、server.transfer
这个才可以说是面象对象开发所使用的方法,其使用server.transfer方法把流程从当前页面引导到另一个页面中,新的页面使用前一个页面的应答流,所以这个方法是完全面象对象的,简洁有效。
server.transfer是从当前的aspx页面转到新的aspx页面,服务器端执行新页并输出,在新页面中通过context.handler来获得前一个页面传递的各种数据类型的值、表单数据、querystring.由于重定向完全在服务器端完成,所以客户端浏览器中的url地址是不会改变的。调用server.transfer时,当前的aspx页面终止执行,执行流程转入另一个aspx页面,但新的aspx页面仍使用前一aspx页面创建的应答流。
ps:比较server.transfer和response.redirect的区别。
(1)server.transfer在服务器端完成,所以客户端浏览器中的url地址是不会改变的;response.redirect是客户端完成,向服务器端提出新的页面处理请求,所以客户端浏览器中的url地址是会改变的。
(2)server.transfer在服务器端完成,不需要客户端提出请求,减少了客户端对服务器端提出请求。[2]
(3)server.transfer只能够转跳到本地虚拟目录指定的页面,也就是工程项目中的页面,而response.redirect则十分灵活,可以跳转到任何url地址。
(4)server.transfer可以将前一个页面的各种类型的值传到新的页面;response.redirect则只能借助url中带参数或是结合上面四种办法把各种类型的值传到新的页面。
优点:1.直接在服务器端重定向,使用简单方便,减少了客户端对服务器端提出请求。
2.可以传递各种数据类型的值和控件的值。
缺点:1.客户端浏览器中的url地址是不改变,会导致在新的页面可能出现一些意想不到的问题。比如如果源页面和目的页面不在同一个虚拟目录或其子目录下,那么使用相对路径的图片、超链接都会导致错误的指向。
使用方法:1.在源页面的代码中,使用page类的server.transfer跳到另一个页面传递页面数据:server.transfer("b.aspx","false")。
2.在目的页面中,使用context.handler来接收数据:formerpage formerpage = (formerpage)context.handler; 然后用formerpage的属性和方法来获取前一个页面的值,或者直接用context.items["myparameter "]
例子:(1)a.aspx
复制代码 代码如下:
public string name
{
get{ return label1.text;}
}
private void button1_click(object sender, system.eventargs e)
{
server.transfer("b.aspx");
}
(2)b.aspx
复制代码 代码如下:
private void page_load(object sender, eventargs e)
{
a newweb; //实例a窗体
newweb = (source)context.handler;
string name;
name = newweb.name;
}
以上就是常用的几种页面间传值的方法,我一般使用session和querystring来传值,少数情况会使用到cookie。本篇文章仅仅是介绍这几种方法的使用方法,内部原理没有过多的解释,关于session的存储方式请参见:
上一篇: PHP单例模式定义与使用实例详解