亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

ASP中Session的運作原理

添加時間:2014-9-15 3:16:40  添加: 思海網絡 

首先來講講 Session 的好處,它可以用來記錄客戶端私有的資料變量,并且在時間范圍內不會消失。這真的是很重要的功能,尤其是有會員的系統必須要用到的。像是會員的登入帳號、時間、狀態以及許許多多該記錄的實時數據﹝如購物系統記錄使用者的購物籃內的商品﹞,這些信息屬于各使用者私人所需要,通常開發者都是使用 Session 記錄處理。

然而,在 ASP 中的 Session 是使用 Cookies 所構成,服務器將所有的 Session 內記錄的資料,以 Cookies 的方式傳至用戶的瀏覽器。通常一般瀏覽器會將這些 Cookies 存起來,每當使用者點選連結,再次與服務器做聯機時,瀏覽器就會把這些 Cookies 傳回 Server 供做處理。這即是 Session 的運作原理,當資料量大一點時,由于必須傳出去又收回來,不但吃線路頻寬,效能相對降低,因為 Server 必須花費更多的資源在做聯機處理和重新配置內存等初始動作。現在你可能會想『我必須用這功能,只好犧牲點了』,不過本文講 Session 一方面是教導大家少用;另一方面當然是有替代辦法,緊接著上場的,就是同屬 Global.asa 內的 Application 對象。

Application 也是記錄處理暫時資料的好手,各方面的能力和用法都和 Session 一樣,只不過相較之下,它所記錄的資料是屬于公用的,也就是任何使用者都可以共享的變量空間。Application 不像 Session ,不是將資料傳給使用者,等下一次聯機再讀取回來,它是直接記錄在 Server 上的內存,相對之下效能上快上 Session 許多。

由于 Application 對象是公用的,首先必須做的,就是要把一塊公用的區域規劃給各個使用者,讓每個用戶擁有自己的區域可以記錄資料,以達到仿真 Session 的目的。現在有兩種做法:

一、在 Server 激活時事先初始化建立及分配使用者內存空間,通常這種做法雖然一 Server 開機就先占了許多資源,但也省去了以后每當使用者聯機就必須做一次分配的麻煩。但有個限制,使用這種方法必須限制最大人數,由于是一激活就初始化,我們只能預估建立某數量的內存空間,所以這種方法通常用于聊天室這種小型的程序上。

二、這種方法對于大型應用程序來說應該算較恰當的,采用動態的分配法,當使用者第一次聯機到 Server 上才開始分配資源給此用戶。這兩種仿真 Session 的方案,目的都是減輕 Session 資源的消耗,但畢竟還是無法完全替代,我們還是需要使用到一點點 Session,至少對 Server 已經能減輕不少負擔了。

第一方案

首先我們開始第一個方案的實作,由于是激活時初始化 Application,我們當然要從 Global.asa中著手:

已經完成初始化了,但如何使用呢?我們只要在使用者登入的地方,把原本使用 Session 儲存的資料,如帳號、登入時間,改成我們建立好的 Application 對象中就可以了:

'尋找未被使用的空間

For i = 1 To Application("ClientMax")

If Application("User_Status_" & i) = 0 Then

'使用者暫時編號

Session("Index") = i

'鎖定

Application Application.Lock

'設成已使用的狀態

Application("User_Status_" & i) = 1 '放入變量數據

Application("User_Account_" & i) = Account

Application("User_Logtime_" & i) = Now()

'解除鎖定

Application.Unlock

Exit For

End If

Next 

要取得使用者的相關變量數據則就像下面的做法:

Response.Write(Application("User_Account_" & Session("Index")) 

你可能會發現,不是說不要使用 Session 嗎?那為什么上面的原始碼中還有 Session 的存在?前面也說過,這替代方案并不能完全代替掉 Session,瀏覽器并不是一直和 Server 處于聯機狀態的,讀取完頁面就斷線,那我們要怎么知道下次聯機的還是同一個人呢?這時候就必須要靠 Session,我們給使用者一組實時的編號,此編號就是使用者于 Application 上變量空間的號碼,你可以想象成銀行中有很多的保險箱,你擁有一支鑰匙,而鑰匙上有編號,鑰匙上的編號可以讓行員帶領你去你自己的保險箱。此方法尚還有改進之處,但對小型的應用程序已經是很夠用了。

第二方案

關于上一方案,你可能也想到,我們自訂的編號使用了 Session 來記錄,講到編號,Session 對象有提供一個“ SessionID ”方法。沒錯,不管我們要不要使用,Server 都會自動幫每個用戶編列號碼,且此號碼不會重復,至于這號碼就是用 Session.SessionID 取得。這編列號碼是 Session 一定會做的動作,我們就可利用它代替我們自己寫的編號程序,亦又省了一道功夫,甚至有更大的擴充性。但基本上,上面的第一個方案還是有它的用途在,像是會限制人數的聊天室等等小應用程序,接下來的第二替代方案,就是針對較大型的系統了。

每秒上站人數達數百數千甚至上萬人的網站,使用之前的方案,必定是行不通的。假設你將上限人數設 10000 ,Server 一激活就會幫你切出一萬個區域準備給一萬個使用者,假若一個區域中有 5 個變量,一個變量占 32 字節(Byte),10000 個就占了 320000 K(320MB) 以上,Server 一激活就塞了那么多的垃圾到內存,效能勢必還沒上戰場就降低不少;而且別看這些數字很少,以為自己的 512 MB 會夠用,上面的數字是假設一個最低數字,加上 Server 在配置內存時會額外使用到多少資源不得而知,所以只會更多不會更低。因此解決辦法只有動態配置使用者變量空間,當有使用者與 Server 聯機時才切一塊區域出來,如此便不須要事先就配置好龐大內存。

第二方案做起來是比較簡單,請把第一方案的東西全部丟掉,我們不需要動到 Global.asa,只需要改使用者登入的地方和其它有用到的地方:

'鎖定 ApplicationApplication.Lock '放入變量數據

Application("User_Account_" & Session.SessionID) = Account

Application("User_Logtime_" & Session.SessionID) = Now() '解除鎖定Application.Unlock 

要取得使用者的相關變量數據則就像下面的做法:

Response.Write(Application("User_Account_" & Session.SessionID)) 

關鍵字:ASP、服務器、數據

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站