基於ActiveX控件技術的B/S模式單點登錄方法

摘   要: 利用ActiveX控件技術,結合B/S模式與C/S模式的雙重優點,將C/S模式中的socket網絡通信技術移植於B/S模式中,實現單態模式登錄,爲基於B/S模式應用系統的客戶端與服務器的通信提供了一種新的解決方案。
關鍵詞: 單態; B/S模式; C/S模式; ActiveX組件

    單態(Singleton)模式的主要作用是使得一個類Class只有一個實例存在,即該模式僅允許有且僅有一個實例在運行。在很多C/S模式的軟件中經常會遇到單態模式的應用。用戶用一個賬號登錄系統之後,如果想再用第二個賬號登錄,必須先把第一個賬號註銷。該模式在C/S模式中實現比較簡單,但在B/S模式中實現卻比較複雜。在B/S模式中,瀏覽器本身並不是單態模式,用戶可以打開多個瀏覽器來登錄同一個系統,例如在瀏覽器的實例1中用“張三”登錄,再打開瀏覽器的實例2,用“李四”登錄,這時雖然是用兩個瀏覽器實例在系統中登錄了兩個賬號,但這兩個實例之間會相互影響,特別是與服務器通信時,容易帶來通信對象錯誤的問題。
    B/S模式程序中一般會採用Session或cookie來保存登錄信息,便於在其他的頁面中使用,以避免多次重複登錄系統,即所謂的單點登錄(SSO)模式。在前面所舉的例子中,用“張三”登錄後,可將其保存在session中,令Session[‘username’]=“張三”;如果再用“李四”登錄,同樣也可保存在Session中,Session[‘username’]=“李四”;由於系統中的Session是唯一的,所以這時Session[‘username’]會覆蓋前面的值,使得在用“張三”登錄的系統中實際保存的登錄信息變成了“李四”。
1 單態登錄模式功能
    本文所提到的單態登錄模式擬實現以下功能:
    (1) 在一臺機器上只能登錄一個賬號,如果已經登錄了一個賬號,再次登錄時則提示登錄失敗。
  (2) 一個賬號最多只能在一臺機器上登錄,如果要登錄的賬號已在其他的機器上登錄了,則提示登錄失敗。
  實現此項功能的好處之一是在客戶端與服務器進行通信時,在查找通信對象時不至於發生錯誤。
  單態模式登錄在C/S模式中可以採用很多方法來實現上述功能,但在B/S模式中實現起來卻比較困難。最簡單的方法是在數據庫中建一個數據表Login(字段爲UserName和LoginIP),用來保存已登錄的登錄賬號和登錄機器的IP信息。每次登錄時,先查一下該數據表,確定要登錄的賬號在Login表中是否已存在,如果不存在則表明該賬號尚未登錄,允許登錄;如果存在則表明已被登錄,不可再登錄。退出系統時,先將Login表中對應的記錄刪除掉。
  該方法存在的最大問題是:當登錄系統後,若出現非正常退出系統的情況(如突然斷電、程序崩潰等),則無法將Login表中的記錄清除。使得下次登錄查詢Login表時,誤以爲該賬號仍在登錄中,導致登錄失敗。
  有人提出每隔一定時間(如30 s)查詢Session來判斷用戶是否在線,這種方法一方面不能保證百分之百地解決問題,另一方面會給服務器帶來不小的負擔。本文所給出的B/S模式的單態模式登錄方法是利用ActiveX技術結合C/S模式與B/S模式的特點,在ActiveX控件中運用網絡通信技術來解決前面所提到的問題。
2 關鍵技術
  ActiveX是微軟提出的採用COM(Component Object Model)和DCOM(Distributed Component Object Model)使軟件組件在網絡環境中進行交互的一組技術集,它是在COM之上建立的一種理論和概念,與具體的編程語言無關,包括ActiveX Dll組件和ActiveX控件。
  本文采用的方法是ActiveX控件。在ActiveX控件中,運用socket網絡通信技術實現客戶端與服務器之間的通信,或者客戶端與客戶端之間的直接通信。用戶可在不安裝客戶端程序的情況下直接通過瀏覽器與服務器或其他客戶端進行通信。Activex控件可直接嵌入Web頁面,在Web頁面中通過<object>標籤來創建,
<object>標籤包含控件的類ID(CLSID),用於識別需要實例化的ActiveX控件,<object>標籤中也可指定控件的CodeBase屬性值,供用戶查找和自動下載該控件並在本地註冊,訪問和控制遠程服務器的數據:如下面代碼所示:
    <object id= "SendCtr" width=0 height=0
  classid="clsid:6571016D-39C4-47AB-9425-9995F68AABE4" codebase="SendMsg.CAB"></object>。
    控件技術的具體實現過程爲:當瀏覽器發出請求時,Web服務器向用戶瀏覽器回傳內嵌ActiveX控件的頁面,由瀏覽器負責解釋。在解釋過程中首先用該控件在頁面中註明的ID值,在本地的註冊表內進行查詢,若已經存在,則說明該控件已經在本地安裝,然後通過註冊表中的相關信息直接使用該控件;否則就要根據頁面中所提示的該控件所在的服務器上的路徑到服務器上下載並且自動完成在本地的安裝註冊,使該控件成爲本地資源,供以後使用。當Web服務器提供更高版本的ActiveX控件時,瀏覽器會自動下載新的控件,並自動安裝,覆蓋原來的控件。控件提供了接口方法,可以在頁面中用JavaScript腳本語言來調用,如:
  document.getElementById("SendCtr").Send(“192.168.
0.13”,”Hello!”);
  此處調用的是SendCtr控件的Send方法,用於向IP爲“192.168.0.13”發送消息”Hello!”。
3 實現原理
 要實現網絡通信的功能,可在頁面中加入兩個activex控件:SendMsg和RecvMsg,一個用於發送消息,另一個用於接收消息。SendMsg控件放在登錄頁面中,RecvMsg控件放在登錄後的用戶操作界面中,每次登錄時,如果發現要登錄的賬號在Login表中已經存在,則先由SendMsg控件檢測目的賬號是否在線,如果檢測出不在線,說明該賬號是上次登錄後非正常退出了,使得Login表沒有及時刪除該條記錄,所以先將該記錄刪除掉,再將本次登錄的記錄插入Login 表中;如果檢測到對方在線,則提示該賬號已被人登錄了,本次登錄失敗,可由邏輯流程圖(如圖1)實現上面提到的兩個功能(設登錄賬號爲zhangsan,本機IP爲192.168.0.13)。

4 核心代碼
   在SendMsg控件中,提供了一個接口函數:CheckIsOnLine(LPCTSTR  strDestIP)。該接口函數僅有一個參數strDestIP,即要檢測是否在線的目的IP。該函數用來檢測目的IP上的系統是否在線,實現的原理也較簡單:給該IP發送一個消息,如果在規定時間內收到回覆,則說明對方在線,因爲只有其在線,才能在登錄後的用戶界面中用RecvMsg控件回覆消息。CheckIsOnLine內部實現主要源碼如下:
CheckIsOnLine(LPCTSTR strDestIP)
{
    char msg[10];
    strcpy_s(msg,".");
    sockaddr_in  checkaddr;
    checkaddr.sin_family = AF_INET;
    checkaddr.sin_addr.S_un.S_addr = inet_addr(strDestIP);
    checkaddr.sin_port = htons(5002);
//連接目的客戶端,向目的客戶端發送信息".",看有無回覆
    sendto(m_Socket,msg,10,0,(sockaddr*)&checkaddr,sizeof
(checkaddr));
         fd_set   rfd;   
    FD_ZERO(&rfd);  
    FD_SET(skt,&rfd); 
    timeval   time;  
    time.tv_sec   =   0;  
    time.tv_usec  =   500; 
    int iResult = select(0,&rfd,NULL,NULL,&time);
//檢測在500 ms內有無回信
    if(!iResult)    //對方沒有回信
    {CString strSql = "delete Login where LoginIP =′"+ strDestIP +"′";
    m_Ado.CmdExcute(strSql,FALSE);        
    //將Login表中數據刪除
    }
    else    
    {   char* pData = new char[1024];
        memset(pData,0,1024);
        sockaddr_in addr;
        int factsize = sizeof(sockaddr);
        int ret =recvfrom(m_Socket,pData,1024,0,(sockaddr*)&addr,&factsize);
        if (ret > 0)            //對方在線,提示登錄失敗
        {
MessageBox("該用戶已登錄且尚未退出系統,登錄失敗!","提示");
        }
    }
}
    在RecvMsg控件中只需在接受消息時,判斷消息如果爲".",回覆一個消息即可。
    本文所給出的方法已在Windows XP系統、ASP.net3.5、IE7.0環境下測試通過。利用該方法也可以實現WebQQ的即時通信功能。利用Activex組件技術,可以很好地發揮B/S模式與C/S模式的雙重優點,採用混合工作模式及合理的功能配製,克服單一的B/S模式或單一C/S模式安全與效率、功能與應用的多種矛盾與不足,爲開發一個完善的應用系統提供借鑑。將ActiveX技術應用於B/S監控軟件中,不僅增強了B/S監控軟件的功能,加快了軟件的開發速度,而且適應了當前軟件開發向模塊化、開放化發展的趨勢,提高了系統的實時性、可靠性和可擴展性。ActiveX技術應用於B/S模式彌補了單B/S模式的不足,比B/S和C/S結合的方式簡單實用(不需要安裝C/S客戶端),可以用在商業化的在線殺毒、在線點播、在線考試等諸多領域,具有較大的應用參考價值。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章