Session对象详解
一、Session对象的成员概述
⒈Session对象的集合
Contents :没有使用<OBJECT>元素定义的存储于特定Session对象的所有变量的集合。
StaticObject:使用<OBJECT>元素定义的、存储于Session对象中的所有变量的集合。
例:在default.asp中有如下赋值
Session("a")="a"
Session("b")=128
Session("c")=false
则有contents集合
Session.Contents(1)="a"
'也可写为Session.Contents("a")="a"
Session.Contents(2)=128 '也可写为Session.Contents("b")=128
Session.Contents(3)=false '也可写为Session.Contents("c")=false
⒉Session对象的属性
CodePage: 可读/可写。整型。定义用于在浏览器中显示页内容的代码页。代码页是字符集的数字值,不同的语言使用
不同的代码页。例如,ANSI代码页为1252,日文代码页为932,简体中文代码页为936。
LCID : 可读/可写。整型。定义发送给浏览器的页面地区标识。LCID是唯一地标识地区的一个国际标准缩写,例如,
2057定义当前地区的货币符号是"£"。
SessionID: 只读。长整型。返回本会话的会话标识符。每创建一个会话,由服务器自动分配一个标识符。可以根据它
的值判断两个用户是谁先访问服务器。
Timeout : 可读/可写。整型。为会话定义以分钟为单位的超时限定。如果用户在这个时间内没有刷新或请求任何一个
网页,则该用户产生的会话自动结束。缺省值是20。以上属性在实际应用中作用不大,而且基本上不需要怎么修改,这几个属性也没什么特殊的地方。
⒊Session对象的方法
Contents.Remove("变量名"): 从Session.Contents集合中删除指定的变量
Contents.Removeall() : 删除Session.Contents集合中的所有变量
Abandon() : 结束当前用户会话并且撤消当前Session对象。
Session对象的Contents.Remove("变量名")和Contents.Removeall()方法与Application对象的基本上没什么区别,为帮助理解,可以参照上面的例子将Application改为Session。这里要说明一下的是Contents.Removeall()和Abandon()的区别,执行这两个方法都会释放当前用户会话的所有Session变量,不同的是Contents.Removeall()单纯地释放Session变量的值而不终止当前的会话,而
Abandon()除了释放Session变量外还会终止会话引发Session_OnEnd事件,希望大家注意两者的区别。
⒋Session对象的事件
OnStart: 当ASP用户会话产生时触发,一旦有任一用户对本服务器请求任一页面即产生该事件。
OnEnd : 当ASP用户会话结束时触发,当使用Abandon()方法或超时也会触发该事件。
这两个事件和Application的OnStart、OnEnd事件一样,也是必须放在Global.asa文件里,下面就重点和大家研究一下这四个事件的使用。