| ASP.NET中的状态管理(3) |
|
作者:小秦 文章来源:转载 点击数: 更新时间:2005-3-13 |
| [ 字体:缩小 正常 放大 | 双击自动滚屏 ] |
请选择合适的字体颜色:
|
|
2、服务器端的状态管理 信息存储在服务器上,尽管其安全性较高,但会占用较多的web服务器资源。 A、Aplication对象 Aplication对象提供了一种让所有在Web应用服务器中运行的代码访问的存储数据的机制,插入应用程序对象状态变量的数据应该能够被多个对话共享,而且不会频繁地改变。正是因为它能够被全部应用程序所访问,因此,我们需要使用Lock和UnLock对避免其中的值出现冲突。 [c#] Application.Lock(); Application[“mydata”]=”mydata”; Application.UnLock(); B、Session对象 Session对象可以用来存储需要在服务器的多次请求-应答期间和对网页的请求期间进行维护的指定对话的信息。Session对象是每个对话的存在的基础,也就是说不同的客户端生成不同的Session对象。存储在对话状态变量中的数据存在的周期较短。 每个活动的ASP.NET对话是由一个包含合法的URL ASCII字符、长度为120位的SessionID字符串唯一确定和跟踪的。SessionID的值是由一个能够保证唯一性的算法生成的,以便对话之间不会冲突,SessionID的随意性使得我们很难猜测出一介现有对话的ID。 根据应用程序的配置设置情况,SessionID通过HTTP cookie或修改后的URL在客户端-服务器请求之间进行传输。那么,如何设置应用程序配置的对话装备方法。 每个web应用程序必须有一个名字为web.config的配置文件,它是基于XML文件的。下面是一个名字为sessionState的对话: cookieless选项的值为true或false。当其值为false(缺省值)时,ASP.NET将使用HTTP cookie来识别用户;当其值是true时,ASP.NET将随机地生成一个唯一的号码,并将它放在被请求的文件的前面,这一号码是用来识别用户的,我们能够在IE的地址栏中看到它: http://localhost/Management/(2yzakzez3eqxut45ukyzq3qp)/Default.aspx OK,下面我们再回到session对象。 [c#] file://存储信息 Session[“myname”]=”Mike”; file://获得信息 myname=Session[“myname”]; C、数据库 数据库将使我们能够存储大量的与Web应用程序中的状态相关的信息,有时,用户会使用唯一的ID频繁地访问数据库,我们可以将它存储在数据库中,在对网站中网页的多次请求中使用。 总结 ASP.NET中的功能和工具比ASP中更多,使我们能够更有效和高效地管理网页的状态。具体选择哪种方法与你的应用程序有关,在选择时可以考虑下面的问题: ·需要存储多少信息? ·客户端接受持久的还是内存中的cookie? ·希望在客户端还是在服务器端存储信息? ·要存储的信息需要保密吗? ·希望你的网页的性能如何?
|
|
| 编程文章录入:小秦 责任编辑:小秦 |
上一篇编程文章: ASP.NET中的状态管理(2) 下一篇编程文章: 用ASP.Net编写留言本 |
| 【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】 |