明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

ASP實用大全-ASP對象(6)

[摘要]深入研究Application和Session對象(2)   在本例中,用application("online")變量記錄已經(jīng)登錄社區(qū)的在線人數(shù),因為一旦有用戶訪問服務器而不管用戶是否登錄,都會產(chǎn)生OnStart事件,所以不能在OnStart事件里使Applicaito...

深入研究Application和Session對象(2)

      在本例中,用application("online")變量記錄已經(jīng)登錄社區(qū)的在線人數(shù),因為一旦有用戶訪問服務器而不管用戶是否登錄,都會產(chǎn)生OnStart事件,所以不能在OnStart事件里使Applicaiton("online")加一。因為不管是否是登錄用戶的會話結(jié)束都會產(chǎn)生OnEnd事件(假如有訪客訪問了服務器但并不登錄社區(qū),他的會話結(jié)束后也會產(chǎn)生OnEnd事件),所以在Session_OnEnd事件里用了句if語句來判斷是否為已登錄用戶的OnEnd事件,如果是才將在線人數(shù)減一。

  這只是一個統(tǒng)計在線人數(shù)的簡單例子,對于一個完整的虛擬社區(qū)來說,僅僅統(tǒng)計有多少人在線是不夠的,在本例中數(shù)據(jù)庫里有個online字段是用來記錄用戶的在線狀態(tài),用戶登錄的時候,在login.asp里將online設為1,但用戶離線時并沒有將online設為0,要完善它,就要修改一下Session_OnEnd事件,在該事件里將online設為0。

  ===global.sas===

 。約cript LANGUAGE="VBScript" RUNAT="Server">

  Sub Application_OnStart

   application("online")=0

   set application("conn")=Server.CreateObject("ADODB.Connection")

   application("db")=Server.MapPath("\bbs.mdb") '此處最好使用絕對路徑\bbs.mdb,下文有詳細介紹

  
End Sub

  sub Application_OnEnd

   set application("conn")=nothing

  End Sub

   Sub Session_OnStart

  End Sub

  Sub Session_OnEnd

   if session.contents("pass") then '判斷是否為登錄用戶的Session_OnEnd

     application("con").open ="driver={Microsoft Access Driver (*.mdb)};dbq="&application("db")

      application.lock

      application("online")=application("online")-1

      application("con").Execute ("update friends set online=0 where id="&session.contents("id"))

      application.unlock

      application("con").close

   end if

  End Sub

  </script>

  ==============

  至此,完整的代碼已經(jīng)完成了。因為在Application和Session的OnEnd事件里不能使用Server對象,所以要將數(shù)據(jù)庫的連接及數(shù)據(jù)庫在服務器上的物理地址(d:\inetpub\wwwroot\bbs.mdb)存儲在application變量中,并在Application_OnStart事件中預先處理。同理,在Session_OnEnd事件中不能用session("pass")來代替session.contents("pass")(以下有詳盡說明)。

  四、本文實例中值得引起注意的兩點

 、監(jiān)nEnd事件里的session.contents

  剛開始接觸global.asa的朋友經(jīng)常會將上面Session_OnEnd事件里的

  if session.contents("pass") then 寫成

  if session("pass") then,

  這樣的話系統(tǒng)不會提示錯誤,但是永遠也不會執(zhí)行then后面的內(nèi)容,這是因為在OnEnd事件里禁止使用Session對象,但是可以用Session對象的集合來調(diào)用session變量。因為IIS并沒提示任何錯誤信息,所以筆者曾經(jīng)在這上面浪費了很多時間。在此希望大家引以為鑒!

  ⒉Application_OnStart事件里用Server.MapPath獲取數(shù)據(jù)庫的物理地址時應使用絕對地址為了說明這個問題,大家可以做個實驗:將上面Application_OnStart事件里的

  application("db")=Server.MapPath("\bbs.mdb")改為:

  application("db")=Server.MapPath("bbs.mdb")

然后在d:\inetpub\wwwroot\目錄下建立一個test子目錄,寫一個temp.asp在test目錄里。

  ====test.asp====

 。迹esponse.write application("db")%>

  ================

再將temp.asp拷貝一份放在根目錄下(d:\inetpub\wwwroot\)。用記事本打開global.asa,再打開兩個瀏覽器,瀏覽器A輸入地址http://localhost/temp.asp,按回車,將在瀏覽器上輸出:

  d:\inetpub\wwwroot\bbs.mdb

然后,在記事本的窗口上點"文件"菜單,選"保存"(使global.asa的修改時間改變,從而使IIS重啟動所有服務),再在瀏覽器B輸入地址http://localhost/test/temp.asp,按回車,在瀏覽器上輸出的是:

  d:\inetpub\wwwroot\test\bbs.mdb

global.asa文件雖然是放在站點根目錄下,但是如果在server.mappath中使用的是相對地址,而觸發(fā)Application_OnStart事件的用戶第一次訪問的頁面又不是屬于根目錄的話,得到數(shù)據(jù)庫的物理地址將不會是期望的結(jié)果,希望大家要特別小心。