设为首页
收藏本站
最新电影
> 子栏目 Asp | Jsp | XML | XSL | Div+Css | 自定义函数 | 数据库 | 脚本特效
您现在的位置: 首页=>后台技术=>Asp 订阅本栏目  
cookies和session的关系
时间: 2007-09-28 21:38:41 阅读次数:4845

第 1 页 cookies和session的关系[1]
第 2 页 cookies和session的关系[2]




2飞飞Asp技,术乐园Session其实指的就是访问者从到达某个特定主页到离开为止的那段时间

一访问者都会单独获得一个Session在Web应用程序中,当一个用户访问该应用

时,Session类型的变量可以供这个用户在该Web应用的所有页面中共享数据;如

果另一个用户也同时访问该Web应用,他也拥有自己的Session变量,但两个用户

之间无法通过Session变量共享信息,而Application类型的变更则可以实现站点

多个用户之间在所有页面中共享信息



1、SessionID属性
该属性返回当前会话的唯一标志,为每一个Session分配不同的编号
我曾在开发过程中就遇到对用户的控制问题它要实现的功能就是,针对某

个网站的一个模块,当一个会员登录后正在看此模块时,另一个人用同样的会员

名登录,就不能浏览这个模块也就是说一个会员名同时只能一个人浏览此模块

我通过用会员名(假设为UserID,唯一)和SessionID来实现了控制当会员

登录时,给这个会员一个Session记录登录状态如:Session("Status")="Logged

",同时把这个会员的Session.SessionID写入数据库当他要浏览此模块时,先

判断其是否登录,若已经登录再判断它的SessionID是否与数据库记录的相同,

如果不同则不能访问这样,当另一个用户用相同的会员名登录时,那么数据库

中记录的就是新的SessionID,前者访问此模块时就不能通过检查这就实现了

一个会员名同时只能一个人浏览某个模块这个功能在一些收费网站有很有特别

作用,它防止了一个会员名给多个人浏览的问题,为公司保障了利益



2、TimeOut属性
该属性用来定义用户Session对象的时限如果用户在规定的时间内没有刷

新网页,则Session对象就会终止一般默认为20分钟



3、Abandon方法
该方法是Session对象的唯一方法,可以清除Session对象,用来消除用户的

Session对象并释放其所占的资源如: <% Session.Abandon %>
4、Session_OnStart和Session_OnEnd事件
和Application一样,当对象的例程每一次启动时触发Session_OnStart事件

,然后运行Session_Onstart事件的处理过程也就是说,当服务器接收到应用

程序中的URL的HTTP请求时,触发此事件,并建立一个Session对象同理,这个

事件也必须定在Global.asa文件中
当调用Session.Abandon方法时或者在TimeOut的时间内没有刷新,这会触发

Session_OnEnd事件,然后执行里面的脚本Session变量与特定的用户相联系,

针对某一个用户赋值的Session变量是和其他用户的Session变量完全独立的,不

会存在相互影响
Session应用一列:
与Application一样,一个被定义为Session类型的数组只能将整个数组作为

一个对象,用户不能直接改变Session数组中某个元素的值为了创建一个Sessi

on数组,需先定义一个普通的数组,并对它的每一个元素赋初值,最后把它定义

为一个Session数组如:
<%
dim array()
array=array("jeff","zhu","male")
Session("info")=array
Response.write Session("info")(0) &"-"
Response.write Session("info")(1) &"-"
Response.write Session("info")(2) &"<br>"
%>
<hr>
<%
array(0)="jun"
array(1)="li"
array(2)="female"
Session("info")=array
Response.write Session("info")(0) & "-"
Response.write Session("info")(1) & "-"
Response.write Session("info")(2) & "<br>"
%>

以上这段程序输出结果是:
jeff-zhu-male
_____________
jun-li-female


Session是怎样工作的?

Session其实是利用Cookie进行信息处理的,(参见后面有关Cookies的介绍),

当用户首先进行了请求后,服务端就在用户浏览器上创建了一个Cookie,当这个

Session结束时,其实就是意味着这个Cookie就过期了
为这个用户创建的Cookie的名称是ASPSESSIONID这个Cookie的唯一目的就是为

每一个用户提供不同的身份认证
注:如果你对名字是ASPSESSIONID的COOKIE感到好奇,你可以利用ServerVariab

les集合的COOKIE Header来接受这个信息,参看下面这个脚本:
<%=Request.ServerVariables(“HTTP COOKIE”) %>
你可以刷新不止一次而显示结果依然不变如果希望对ServerVariables集合有

更多了解,那么请去看第14章
Session变量自己不会存在用户浏览器上不过,ASPSESSIONID这个cookie需要

使用session变量server使用ASPSESSIONID

cookie来将特定的用户和特定的session信息联系起来没有cookie的话,Serve

r就不会了解到每一个特定用户在网站中移动的信息
利用SessionID变量存储ASPSESSIONID

cookie和直接对名为ASPSESSIONID的cookie赋值有很大不同微软利用了一个复

杂的数学算法对SessionID进行了加密措施,以防止黑客猜测出SessionID的值并

且依据这个获得不该获得的身份或权限
注:你可以用两种方法屏蔽掉SessionID,一种是将全站进行屏蔽,另外一种是

将一个单独Active Server Page进行相应屏蔽
如果想要将整个站点的Session操作进行屏蔽,你可以使用Internet Service

Manager从Application设置对话框,点击Active Server

Pages表并且取消对Enable Session State选项的选择
你还可以在特定的Active Server Page的首行加入使之屏蔽的语句来进行这种操


<% EnableSessionState=False %>
由于Session对象使用了Cookies,那么它的兼容性就受到了限制,一些老的浏览

器显然是不行的,新的浏览器象是NetScape4.0也提供了屏蔽Cookie的选项
这样就出了问题、由于Cookie不能适用于所有浏览器,那么在建站时你就必须注

意了,如果你的网站定位于大众通用,就必须考虑各种不同的用户情况不过现

在确实有可以替代的方法,有些取代Cookies来进行身份认证的方法将在后面的

章节中进行讨论
注:当前浏览器,是否发送一个Cookie在URL是区分大小写的,因此,微软提醒你

最好使用同样的大小写方式,例如一起使用/WWW/mypage.asp和/www/mypage.asp

肯定会使浏览器出错


[上一页] [下一页]
站内搜索    

下一篇conn.Execute(sql)的返回结果

上一篇vbscript Asc 函数 使用介绍

本栏目最新 栏目最新列表
HTTP 401.5 - 未经授权:ISAPI/CGI 应用程序
Asp使用FSO写UTF-8编码文件的方法
asp操作,控制excel的方法
让ewebeditor兼容ie8的方法
Asp实现二级域名的方法
网站优化策划 栏目最新列表
增加网站外链的快速方法
网站上线前必做的30个检查
新的友情链接参考标准(没有google的PR情况
优化Google的AdSense广告的五个工具
王通讲SEO八大基础
站点最新 站点最新列表
微博推广的一些技巧
xhEditor v1.1.7 发布,
收集的一些轻量级非常实
50个新鲜兼容最新版本的
javascript中cookie的设
Excel中出现#VALUE!、#D
jquery插件:飞飞表情插件
十个使用HTML5开发的精彩
支持HTML5的浏览器有哪些
飞妮莫属:漫画:如何写出
历史最热10条信息  
AWStats安装QQ传真IP插件
MIME介绍 及 [1] [2] [3]
巧用Google和迅雷来下载
Transact SQL 常 [1] [2]
VIA Rhine II Fast Ethe
电脑常用端 [1] [2] [3]
Do you get a kick out
十道羊皮卷 欣赏+mp3版+
每日一句:A friend and
经典__悟透JavaScript
相关文章
Session丢失问题解决
cookies和session的
session.contents的
jsp对象实例讲解(三
ECSHOP的SESSION机制
 
 width= 
伟哥博客 西安房产 123最新电影 三四六四