一起谈.NET技术,Application、Session、Cookie、ViewState、Cache、Hidden的区别


方法

信息量大小

作用域和保存时间

应用范围

保存位置

Application

任意大小

整个应用程序的生命期

整个应用程序/所有用户

服务器端

Cache

任意大小

可以根据需要设定

整个应用程序/所有用户

服务器端

Session

小量,简单的数据

用户活动时间+一段延迟时间(一般为20分钟)

单个用户

服务器端

Cookie

小量,简单的数据

可以根据需要设定

单个用户

客户端

Viewstate

小量,简单的数据

一个Web页面的生命期

单个用户

客户端

隐藏域

小量,简单的数据

一个Web页面的生命期

单个用户

客户端

查询字符串

小量,简单的数据

直到下次页面跳转请求

单个用户

客户端

1. Application:用于保存所有用户共用的数据信息。在Asp.Net中类似的配置数据最好保存在Web.config文件中。如果使用Application对象,一个需要考虑的问题是任何写操作都要在 Application_OnStart事件(global.asax)中完成。尽管使用Application.Lock和 Application.Unlock方法来避免写操作的同步,但是它串行化了Application对象的请求,当网站访问量大的时候会产生严重的性能瓶颈。因此最好不要用此对象保存大的数据集。
使用如下:
//存放信息
Application["nameID"]="0001";
//读取信息
String NameID=Application["nameID"].ToString();

2. Session:用于保存每个用户的专用信息。Session中的信息保存在Web服务器的内存中,保存的数据量可大可小。当Session超时或被关闭时将自动释放保存的数据信息。对于小量的数据Session对象保存还是一个不错的选择。
使用如下:
//存放信息
Session["nameID"]="0001";
//读取信息
String NameID=Session["nameID"].ToString();

3. Cookie: 用于保存客户浏览器请求服务器页面的请求信息,其有效期可以人为设置,而且其存储的数据量很受限制,因此不要保存数据集及其他大量数据。而且Cookie以明文方式将数据信息保存在客户端的计算机中,因此最好不要保存敏感的未加密的数据。
使用如下:
//存放信息
Response.Cookie["nameID"].Value="0001";
//读取信息
String NameID=Response.Cookie["nameID"].Value;
 
4. ViewState:常用于保存单个用户的状态信息,可以保存大量的数据但是过多使用会影响应用程序的性能。所有Web服务器控件都使用ViewStat在页面回发期间保存自己的状态信息。每个控件都有自己的ViewState,不用时最好关闭以节省资源。通过给@Page指令添加"EnableViewState= false"属性可以禁止整个页面的ViewState。
使用如下:
//存取信息
ViewState["nameID"]="0001";
//读取信息
string NameID=ViewState["nameID"].ToString();

5. Cache:用于在Http请求间保存页面和数据。它允许将频繁访问的大量服务器资源存储在内存中,当用户发出相同的请求时服务器不再次处理而是将Cache中保存的信息返回给用户,节省了服务器处理请求时间。
使用如下:
//存放信息
Cache["nameID"]="0001";
//存放信息
Cache.Insert("nameID","0001");
//读取信息
String NameID=Cache["nameID"].ToString();
注意: 如果利用缓存提供的清理、到期时间和依赖项等功能,必须使用Cache.Insert方法或Cache.Add方法添加信息。

6. 隐藏域:Hidden控件属于Html类型的服务器控件,可以实现隐藏域的功能,他和其他的空间没什么区别只是不会在浏览器上显示,始终处于隐藏状态。
使用如下:
//存放信息
Hidden.Value="0001";
//读取信息
String NameID=Hidden.Value;

7. 查询字符串:将传递的值连接在URL后面,然后通过Response.Redirect方法实现客户端的重定向。
传递方法如下:
Response.Redirect("/");
执行上面的语句后在IE地址栏显示的URL的代码如下:
http://www.126fm.net/
当跳转到List.aspx后,可以通过下面代码获得传递的信息:
String NameID,GradeID;
NameID=Request.Params["nameID"];
GradeID=Request["gradeID"];
通过比较总结的每一种对象应用的具体环境:
方法 信息量大小 保存时间 应用范围 保存位置
Application 任意大小 整个应用程序的生命周期 所有用户 服务器段
Session 小量,简单的数据 用户活动时间+一般延迟时间(一般为20分钟) 单个用户 服务器段
Cookie 小量,简单的数据 可以根据需要设定 单个用户 客户端
Viewstate 小量,简单的数据 一个Web页面的生存周期 单个用户 客户端
Cache 任意大小 可以根据需要设定 所有用户 服务器段
隐藏域 小量,简单的数据 一个Web页面的生存周期 单个用户 客户端
查询字符串 小量,简单的数据 直到下次页面跳转请求 单个用户 客户端
web.config文件 不变或极少改变的小量数据 直到配置文件被更新 所有用户

时间: 2024-10-05 20:41:33

一起谈.NET技术,Application、Session、Cookie、ViewState、Cache、Hidden的区别的相关文章

asp.net中Session缓存与Cache缓存的区别分析_实用技巧

其中Cookie是保存在客户端的一组数据,主要用来保存用户名等个人信息. Session则保存对话信息. Application则是保存在整个应用程序范围内的信息,相当于全局变量. Session用的比较多. Session缓存与Cache缓存的区别,可以参考如下的几点: 1.最大的区别是Cache提供缓存依赖来更新数据,而Session只能依靠定义的缓存时间来判断缓存数据是否有效. 2.即使应用程序终止,只要Cache.Add方法中定义的缓存时间未过期,下次开启应用程序时,缓存的数据依然存在.

一起谈.NET技术,URI和URL及URN的区别

对于URL,大家都比较熟悉,其他两个词就比较陌生了.URI.URL和URN是识别.定位和命名互联网上的资源的标准途径.1989年Tim Berners-Lee发明了互联网(World Wide Web).WWW被认为是全球互连的实际的和抽象的资源的集合–它按需求提供信息实体–通过互联网访问.实际的资源的范围从文件到人,抽象的资源包括数据库查询. 因为要通过多样的方式识别资源(人的名字可能相同,然而计算机文件只能通过唯一的路径名称组合访问),所以需要标准的识别WWW资源的途径.为了满足这种需要,T

ASP.NET中Application、Cookie、Session、Cache和ViewState_基础应用

我们在做ASP.NET开发的时候经常会用到回话,我们在回话中存储一些数据,下面让我们来一一介绍一下Application.Cookie.Session.Cache和ViewState,以便我们选择在什么时候使用它们. 一.Application Application 提供对所有会话的应用程序范围的方法和事件的访问.还提供对可用于存储信息的应用程序范围的缓存的访问.应用程序状态是可供 ASP.NET 应用程序中的所有类使用的数据储存库.它存储在服务器的内存中,因此与在数据库中存储和检索信息相比,

一起谈.NET技术,ASP.NET的Session 详解

阅读本文章前,需要读者对以下知识有所了解.否则,阅读过程中会在相应的内容上遇到不同程度的问题. 懂得ASP/ASP.NET编程 了解ASP/ASP.NET的Session模型 了解ASP.NET Web应用程序模型 了解ASP.NET Web应用程序配置文件Web.config的作用.意义及使用方法 了解Internet Information Services(以下简称IIS)的基本使用方法 了解如何在Microsoft SQL Server中创建一个数据库. Session模型简介 Sess

session 和 viewstate 的比较

session|比较                   session        viewstate占用服务器资源      true           falsetime out            true           false存储任何.net类型    true           false(只支持strings, integers, Booleans, arrays, ArrayList, hashtable, custom TypeConverters)加重htm

WCF常见问题(1) -- WebService/WCF Session Cookie

原文:WCF常见问题(1) -- WebService/WCF Session Cookie 在.net 3.0推出WCF之前使用的WebService,有的应用有使用Session保持一些信息,在不同的WebMethod中共享存储信息.比如:保持登陆用户的信息等.其原理是应用ASP.NET兼容模式,利用HttpContext来保持请求的上下文. 为了显示WebService/WCF不同应用下的Session/Cookie应用,这里分别创建两个Service应用:一个是WebService Ap

PHP 之session cookie

cookie和session有什么用?   常见的用法,比如在有些网站下载东西需要会员先登陆.http协议本身是无状态的,无法得知顾客是否已经登陆,怎么办呢?cookie和session就可以知道.再比如网上购物,用户身份认证,程序状态记录.购物车怎么知道顾客挑选过哪些商品呢?cookie和session也可以记录.总而言之,cookie和session就是能够记录顾客状态的技术,尽管二者属于不同的技术,但只要cookie能做到的,session也能做到!如果session和cookie一样安全

一起谈.NET技术,ASP.NET Process Model之二:ASP.NET Http Runtime Pipeline[下篇]

ASP.NET Process Model索引 ASP.NET Process Model之一:IIS 和 ASP.NET ISAPI ASP.NET Process Model之二:ASP.NET Http Runtime Pipeline[上篇] ASP.NET Process Model之二:ASP.NET Http Runtime Pipeline[下篇] 二.ASP.NET Runtime Pipeline 现在我们真正进入ASP.NET管辖的范畴,下图基本上囊括整个处理过程涉及的对象

巧解Session cookie

这方法,我自己想的,已经用了1,2年了,希望对有需要的网友有用. 所谓的 session cookie, 就是站台在你登录成功后送上一个 cookie,表示你已经通过验证,但与一般cookie不同的是,他并不会存在你的硬盘上,也就是说: 在你离开浏览器之后,就会消失,也就是意味:下次你重开浏览器,再进此站,此 cookie 已经不见了. 那么,要怎么让这个 cookie 永远有效呢?说永远太久了 我们就来个 50 年不变吧... set win=external.menuArguments s

查看服务器Application/Session变量工具

application|session|变量|服务器 <%@LANGUAGE="javascript" CODEPAGE="936"%> <% Response.Expires = 0; Response.Buffer = true; var tPageStartTime = new Date(); %> <html> <head> <title>网站-Application变量-Session变量<