cookies和session的关系
1。 Cookie是一种发送到客户浏览器的文本串句柄,并保存在客户机硬盘上, 可以用来在某个Web站点会话之间持久地保持数据。Request和Response对象都有 一组Cookie。Request.cookie集合是一系列Cookie,从客户端与HTTP Request一 起发送到Web服务器。反过来,如果你希望把Cookie发送到客户机,就可以使用R esponse.cookie pires属性赋一个过期的日期,就可以删除Cookie。如: 则可以使用以下代码。 个<html>之前,以避免产生错误. Cookies变量。如果有该变量,则说明用户已经访问过该页面,同时输入出访问 次数。如果用户是首次访问该页面,则其计算机内不会有Cookies变量,程序会 显示“欢迎”字样,然后将Cookies变量Visit_num存到用户计算机中,以便该用 户下一次访问该页面时给出“访问的次数”信息。 在Cookies组件中常引入一人的概念“子键”。引用它的语法如下: 所有的“子键”名及值的字符串。例如上面这个例子包含三个“子键”:"Mynam e"、"Gender"和"Myheight",当用户没有指定其“子键”而直接通过Request.Co okies("info")来引用时,则会得到下列字符串: Request.Cookies(cookie)(key)
一访问者都会单独获得一个Session。在Web应用程序中,当一个用户访问该应用 时,Session类型的变量可以供这个用户在该Web应用的所有页面中共享数据;如 果另一个用户也同时访问该Web应用,他也拥有自己的Session变量,但两个用户 之间无法通过Session变量共享信息,而Application类型的变更则可以实现站点 多个用户之间在所有页面中共享信息。
1、SessionID属性 个网站的一个模块,当一个会员登录后正在看此模块时,另一个人用同样的会员 名登录,就不能浏览这个模块。也就是说一个会员名同时只能一个人浏览此模块 。我通过用会员名(假设为UserID,唯一)和SessionID来实现了控制。当会员 登录时,给这个会员一个Session记录登录状态如:Session("Status")="Logged ",同时把这个会员的Session.SessionID写入数据库。当他要浏览此模块时,先 判断其是否登录,若已经登录再判断它的SessionID是否与数据库记录的相同, 如果不同则不能访问。这样,当另一个用户用相同的会员名登录时,那么数据库 中记录的就是新的SessionID,前者访问此模块时就不能通过检查。这就实现了 一个会员名同时只能一个人浏览某个模块。这个功能在一些收费网站有很有特别 作用,它防止了一个会员名给多个人浏览的问题,为公司保障了利益。
2、TimeOut属性 新网页,则Session对象就会终止。一般默认为20分钟。
3、Abandon方法 Session对象并释放其所占的资源。如: <% Session.Abandon %> ,然后运行Session_Onstart事件的处理过程。也就是说,当服务器接收到应用 程序中的URL的HTTP请求时,触发此事件,并建立一个Session对象。同理,这个 事件也必须定在Global.asa文件中。 Session_OnEnd事件,然后执行里面的脚本。Session变量与特定的用户相联系, 针对某一个用户赋值的Session变量是和其他用户的Session变量完全独立的,不 会存在相互影响。 一个对象,用户不能直接改变Session数组中某个元素的值。为了创建一个Sessi on数组,需先定义一个普通的数组,并对它的每一个元素赋初值,最后把它定义 为一个Session数组。如:
Session其实是利用Cookie进行信息处理的,(参见后面有关Cookies的介绍), 当用户首先进行了请求后,服务端就在用户浏览器上创建了一个Cookie,当这个 Session结束时,其实就是意味着这个Cookie就过期了。 每一个用户提供不同的身份认证。 les集合的COOKIE Header来接受这个信息,参看下面这个脚本: 更多了解,那么请去看第14章。 使用session变量。server使用ASPSESSIONID cookie来将特定的用户和特定的session信息联系起来。没有cookie的话,Serve r就不会了解到每一个特定用户在网站中移动的信息。 cookie和直接对名为ASPSESSIONID的cookie赋值有很大不同。微软利用了一个复 杂的数学算法对SessionID进行了加密措施,以防止黑客猜测出SessionID的值并 且依据这个获得不该获得的身份或权限。 将一个单独Active Server Page进行相应屏蔽。 Manager。从Application设置对话框,点击Active Server Pages表并且取消对Enable Session State选项的选择。 作。 器显然是不行的,新的浏览器象是NetScape4.0也提供了屏蔽Cookie的选项。 意了,如果你的网站定位于大众通用,就必须考虑各种不同的用户情况。不过现 在确实有可以替代的方法,有些取代Cookies来进行身份认证的方法将在后面的 章节中进行讨论。 最好使用同样的大小写方式,例如一起使用/WWW/mypage.asp和/www/mypage.asp 肯定会使浏览器出错。 |