您的位置:首页 > 移动开发

状态管理Application和Session、Cache以及Cookie

2008-12-03 22:21 471 查看
Application利用他建立的变量,将是在系统内部任何地方都可以访问的,通常网站的访问统计会用的比较多。要用他的话,我们先得在系统(不是WIN系统哦)中建立一个global.asa文件,事实上Session也是使用的这个文件。

Application是一个共享的对象。当程序开始运行他就建立了,一直持续到程序关闭,他的变量是共享的,所有操作这个程序的人都可以使用,那么这就有麻烦了,如果两个人同时给了他修改变量的命令,他该听谁的呢?所以,这时就使用了悲观的锁定,每一次变量被操作的时候,都是用Lock来锁定他,当操作完再解锁UnLock。

Session就不同了,这个是在每个人进入到程序的时候就建立Session对象,也就是说,Application只有一个,而Session是有多少人用就有多少个,Session是不共享的,当这个人退出程序的时候该对象在系统默认的20分钟后被销毁,当然我们可以人为的去改变这个时间,如果这个人在规定的时间内再访问程序的话,它直接使用先前建立的那个Session对象,可如果特定时间以后再来,那只好再重新建立。

asp、php等语言中Session是依赖于Cookie的,如果用户不接受Cookie,那么Session也不能用,但是.net摒弃了这种做法,我们只需要在web.config文件里面设置Cookieless属性为True,他就可以不依赖谁自立门户了。

Cookie其实就是在硬盘或者浏览器内存中建立一个对象,我们说Session对象时保存在服务器端的,那么Cookie则是保存在客户端的,他们都是为了保存客户的一些信息,Session只能短时间的保存客户的状态,因为毕竟我们得考虑服务器的负载,而Cookie则可以长时间的保存

Cache对象。
除了System.Web.Caching下的Cache外,我们还可以用到HttpContext.Current.Cache以及HttpRuntime.Cache
那么,HttpContext.Current.Cache以及HttpRuntime.Cache有什么区别呢?
从MSDN上的解释可以看出,HttpRuntime.Cache是应用程序级别的,而HttpContext.Current.Cache是针对当前WEB上下文定义的。
然而,实际上,这二个都是调用的同一个对象,不同的是:HttpRuntime下的除了WEB中可以使用外,非WEB程序也可以使用。
而HttpContext则只能用在WEB中。
因此,在可能的情况下,我们尽可能使用HttpRuntime(然而,在不同应用程序之间如何调用也是一个问题)。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: