二、session對象的成員概述
Session對象的成員比application對象多一項屬性,即:集合、屬性、方法、事件
⒈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文件裡,下面就重點和大家研究一下這四個事件的使用。