ASP.NET页面间传值的几种方法的区别和比较

一、QueryString传值:       

1. 优点和缺点 优点:

   1)优点:使用简单,对于安全性要求不高时传递数字或是文本值非常有效。

   2) 缺点:1..缺乏安全性,由于它的值暴露在浏览器的URL地址中的。 2.不能传递对象。  

2.可能出现的问题在处理Resonse.QueryString函数汉字参数传递时,发生不能完整传递参数的具体值的错误,解决有两个方法。

        方法一:需要重新设置Web.config中的encoding和全球化设置。
  1)首行:<?xml version="1.0" encoding="utf-8" ?>更改为:<?xml version="1.0" encoding="GB2312" ?>
        2)<!-- 全球化 此节设置应用程序的全球化设置。 --> <globalization requestEncoding="utf-8" responseEncoding="utf-8" />更改为:<!-- 全球化 此节设置应用程序的全球化设置。 --> <globalization requestEncoding="GB2312" responseEncoding="GB2312" /> [1]
  方法二:使用Server.UrlEncode和Server.UrlDecode对汉字或者特殊字符进行编码和解码。

 二、Server.Transfer传值:

1. 这种方式避免了要传递的值显示在浏览器的地址栏中,但是比较麻烦,Server.Transfer是从当前的ASPX页面转到新的ASPX页面,服务器端执行新页并输出,在新页面中通过 Context.Handler来获得前一个页面传递的各种数据类型的值、表单数据、QueryString.由于重定向完全在服务器端完成,所以客户端 浏览器中的URL地址是不会改变的。 调用Server.Transfer时,当前的ASPX页面终止执行,执行流程转入另一个ASPX页面,但新的ASPX页面仍使用前一ASPX页面创建的应答流。

2.在这里比较一下Server.Transfer和在“一”中使用的Response.Redirect的区别。

    (1)Server.Transfer在服务器端完成,所以客户端浏览器中的URL地址是不会改变的;Response.Redirect是客户端完成,向服务器端提出新的页面处理请求,所以客户端浏览器中的URL地址是会改变的。

    (2)Server.Transfer在服务器端完成,不需要客户端提出请求,减少了客户端对服务器端提出请求。

    (3)Server.Transfer只能够转跳到本地虚拟目录指定的页面,也就是工程项目中的页面,而Response.Redirect则十分灵活,可以跳转到任何URL地址。

    (4)Server.Transfer可以将前一个页面的各种类型的值传到新的页面;Response.Redirect则只能借助URL中带参数或是结合上面四种办法把各种类型的值传到新的页面。

三、Cookie对象变量:

1. Cookie用于在用户浏览器上存储小块的信息,保存用户的相关信息,比如用户访问某网站时用户的 ID,用户的偏好等,用户下次访问就可以通过检索获得以前的信息。所以Cookie也可以在页面间传递值。Cookie通过HTTP头在浏览器和服务器之 间来回传递的。Cookie只能包含字符串的值,如果想在Cookie存储整数值,那么需要先转换为字符串的形式。可以通过遍历Request对象的Cookie集合可以获得所有的浏览器所有的Cookie。

优点: 1.使用简单,是保持用户状态的一种非常常用的方法。比如在购物网站中用户跨多个页面表单时可以用它来保持用户状态。

缺点: 1.常常被人认为用来收集用户隐私而遭到批评。

四、Session对象变量:

1. Session也是针对每一个用户而言的,是存放在服务器端的 ,Session不仅可以把值传递到下一个页面,还可以交叉传递到多个页面,直至把Session变量的值removed 后,变量才会消失,

(1)优点和缺点 优点: 1.使用简单,不仅能传递简单数据类型,还能传递对象。 2.数据量大小是不限制的。

缺点: 1.在Session变量存储大量的数据会消耗较多的服务器资源。

五、Application对象变量:     

1.  Application变量在整个应用程序生命周期中都是有效的,类似于使用全局变量一样,所以可以在不同页面中对它进行存取。它和Session变量的区别在于,前者是所有的用户共用的全局变量,后者是各个用户独有的全局变量。 举个例子来解释: 网站访问的计数器变量一般采用Application变量,多个请求访问时共享这一个变量,均可对它进行操作,该变量可以被整个应用程序的各个页面直接使用。 用户登陆的帐号名一般采用Session变量,多个请求访问时有各自的Session变量,只能对自己的该Session变量进行操作,整个应用程序的各个页面直接使用这个变量来获得用户的基本信息。

优点: 1.使用简单,消耗较少的服务器资源。 2.不仅能传递简单数据,还能传递对象。 3.数据量大小是不限制的。

缺点: 1.作为全局变量容易被误操作。

 

posted @ 2015-08-06 08:50  天下滋味  阅读(454)  评论(0编辑  收藏  举报