- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) > web開(kāi)發(fā) > ASP >
- ASP中Session技巧 默認過(guò)期時(shí)間為20分鐘
寫(xiě)過(guò)稍微大型一點(diǎn) ASP 的人都知道,Session 這個(gè)對象真是好用,它可以用來(lái)記錄使用者私有的資料變量,既安全又方便。但是你真的知道 Session 的運作原理嗎?或許了解以后,你就再也不太敢使用這個(gè)令人又愛(ài)又恨的對象。雖然轉而替代之的方法稍嫌麻煩,但在長(cháng)期考量之下,也就不得不這么做了
首先來(lái)講講 Session 的好處,它可以用來(lái)記錄客戶(hù)端私有的資料變量,并且在時(shí)間范圍內不會(huì )消失。這真的是很重要的功能,尤其是有會(huì )員的系統必須要用到的。像是會(huì )員的登入帳號、時(shí)間、狀態(tài)以及許許多多該記錄的實(shí)時(shí)數據﹝如購物系統記錄使用者的購物籃內的商品﹞,這些信息屬于各使用者私人所需要,通常開(kāi)發(fā)者都是使用 Session 記錄處理。
然而,在 ASP 中的 Session 是使用 Cookies 所構成,服務(wù)器將所有的 Session 內記錄的資料,以 Cookies 的方式傳至用戶(hù)的瀏覽器。通常一般瀏覽器會(huì )將這些 Cookies 存起來(lái),每當使用者點(diǎn)選連結,再次與服務(wù)器做聯(lián)機時(shí),瀏覽器就會(huì )把這些 Cookies 傳回 Server 供做處理。這即是 Session 的運作原理,當資料量大一點(diǎn)時(shí),由于必須傳出去又收回來(lái),不但吃線(xiàn)路頻寬,效能相對降低,因為 Server 必須花費更多的資源在做聯(lián)機處理和重新配置內存等初始動(dòng)作?,F在你可能會(huì )想『我必須用這功能,只好犧牲點(diǎn)了』,不過(guò)本文講 Session 一方面是教導大家少用;另一方面當然是有替代辦法,緊接著(zhù)上場(chǎng)的,就是同屬 Global.asa 內的 Application 對象。
Application 也是記錄處理暫時(shí)資料的好手,各方面的能力和用法都和 Session 一樣,只不過(guò)相較之下,它所記錄的資料是屬于公用的,也就是任何使用者都可以共享的變量空間。Application 不像 Session ,不是將資料傳給使用者,等下一次聯(lián)機再讀取回來(lái),它是直接記錄在 Server 上的內存,相對之下效能上快上 Session 許多。
由于 Application 對象是公用的,首先必須做的,就是要把一塊公用的區域規劃給各個(gè)使用者,讓每個(gè)用戶(hù)擁有自己的區域可以記錄資料,以達到仿真 Session 的目的?,F在有兩種做法:
一、在 Server 激活時(shí)事先初始化建立及分配使用者內存空間,通常這種做法雖然一 Server 開(kāi)機就先占了許多資源,但也省去了以后每當使用者聯(lián)機就必須做一次分配的麻煩。但有個(gè)限制,使用這種方法必須限制最大人數,由于是一激活就初始化,我們只能預估建立某數量的內存空間,所以這種方法通常用于聊天室這種小型的程序上。
二、這種方法對于大型應用程序來(lái)說(shuō)應該算較恰當的,采用動(dòng)態(tài)的分配法,當使用者第一次聯(lián)機到 Server 上才開(kāi)始分配資源給此用戶(hù)。這兩種仿真 Session 的方案,目的都是減輕 Session 資源的消耗,但畢竟還是無(wú)法完全替代,我們還是需要使用到一點(diǎn)點(diǎn) Session,至少對 Server 已經(jīng)能減輕不少負擔了。
第一方案
首先我們開(kāi)始第一個(gè)方案的實(shí)作,由于是激活時(shí)初始化 Application,我們當然要從 Global.asa中著(zhù)手:
已經(jīng)完成初始化了,但如何使用呢?我們只要在使用者登入的地方,把原本使用 Session 儲存的資料,如帳號、登入時(shí)間,改成我們建立好的 Application 對象中就可以了:
代碼如下:
'尋找未被使用的空間
For i = 1 To Application("ClientMax")
If Application("User_Status_" & i) = 0 Then
'使用者暫時(shí)編號
Session("Index") = i
'鎖定
Application Application.Lock
'設成已使用的狀態(tài)
Application("User_Status_" & i) = 1 '放入變量數據
Application("User_Account_" & i) = Account
Application("User_Logtime_" & i) = Now()
'解除鎖定
Application.Unlock
Exit For
End If
Next
要取得使用者的相關(guān)變量數據則就像下面的做法:
Response.Write(Application("User_Account_" & Session("Index"))
你可能會(huì )發(fā)現,不是說(shuō)不要使用 Session 嗎?那為什么上面的原始碼中還有 Session 的存在?前面也說(shuō)過(guò),這替代方案并不能完全代替掉 Session,瀏覽器并不是一直和 Server 處于聯(lián)機狀態(tài)的,讀取完頁(yè)面就斷線(xiàn),那我們要怎么知道下次聯(lián)機的還是同一個(gè)人呢?這時(shí)候就必須要靠 Session,我們給使用者一組實(shí)時(shí)的編號,此編號就是使用者于 Application 上變量空間的號碼,你可以想象成銀行中有很多的保險箱,你擁有一支鑰匙,而鑰匙上有編號,鑰匙上的編號可以讓行員帶領(lǐng)你去你自己的保險箱。此方法尚還有改進(jìn)之處,但對小型的應用程序已經(jīng)是很夠用了。
第二方案
關(guān)于上一方案,你可能也想到,我們自訂的編號使用了 Session 來(lái)記錄,講到編號,Session 對象有提供一個(gè)『 SessionID 』方法。沒(méi)錯,不管我們要不要使用,Server 都會(huì )自動(dòng)幫每個(gè)用戶(hù)編列號碼,且此號碼不會(huì )重復,至于這號碼就是用 Session.SessionID 取得。這編列號碼是 Session 一定會(huì )做的動(dòng)作,我們就可利用它代替我們自己寫(xiě)的編號程序,亦又省了一道功夫,甚至有更大的擴充性。但基本上,上面的第一個(gè)方案還是有它的用途在,像是會(huì )限制人數的聊天室等等小應用程序,接下來(lái)的第二替代方案,就是針對較大型的系統了。
每秒上站人數達數百數千甚至上萬(wàn)人的網(wǎng)站,使用之前的方案,必定是行不通的。假設你將上限人數設 10000 ,Server 一激活就會(huì )幫你切出一萬(wàn)個(gè)區域準備給一萬(wàn)個(gè)使用者,假若一個(gè)區域中有 5 個(gè)變量,一個(gè)變量占 32 字節(Byte),10000 個(gè)就占了 320000 K(320MB) 以上,Server 一激活就塞了那么多的垃圾到內存,效能勢必還沒(méi)上戰場(chǎng)就降低不少;而且別看這些數字很少,以為自己的 512 MB 會(huì )夠用,上面的數字是假設一個(gè)最低數字,加上 Server 在配置內存時(shí)會(huì )額外使用到多少資源不得而知,所以只會(huì )更多不會(huì )更低。因此解決辦法只有動(dòng)態(tài)配置使用者變量空間,當有使用者與 Server 聯(lián)機時(shí)才切一塊區域出來(lái),如此便不須要事先就配置好龐大內存。
第二方案做起來(lái)是比較簡(jiǎn)單,請把第一方案的東西全部丟掉,我們不需要動(dòng)到 Global.asa,只需要改使用者登入的地方和其它有用到的地方:
代碼如下:
'鎖定 ApplicationApplication.Lock '放入變量數據
Application("User_Account_" & Session.SessionID) = Account
Application("User_Logtime_" & Session.SessionID) = Now() '解除鎖定Application.Unlock
要取得使用者的相關(guān)變量數據則就像下面的做法:
代碼如下:
Response.Write(Application("User_Account_" & Session.SessionID))
以往看很多書(shū),都寫(xiě)著(zhù) Session 吃資源吃的很兇,盡量不要用,可是必須用的時(shí)候還是得用,書(shū)里又都沒(méi)教較妥當的解決辦法?,F在當你懂了如何替代 Session,好好去利用吧!或許老是困擾的效能問(wèn)題能因此改善不少!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站