阻止同一Asp.net用戶(hù)重復次登錄代碼 |
作者:佚名 發(fā)布時(shí)間:2011-12-31 瀏覽:3611次 |
同一個(gè)用戶(hù)在某些系統中同一時(shí)間是只能登錄一次的,如果一個(gè)用戶(hù)已經(jīng)登錄了,在退出之前如果再次登錄的話(huà)需要報錯。對于這樣的情況,有什么處理方法呢?在用戶(hù)登錄時(shí),首先判斷此用戶(hù)是否已經(jīng)在Application中存在,如果存在就報錯,不存在的話(huà)就加到Application中(Application是所有Session共有的,整個(gè)web應用程序唯一的一個(gè)對象,達到阻止同一Asp.net用戶(hù)重復次登錄目的: stringstrUserId=txtUser.Text; ArrayListlist=Application.Get ("GLOBAL_USER_LIST")asArrayList; if(list==null) { list=newArrayList(); } for(inti=0;i { if(strUserId==(list[i]asstring)) { //已經(jīng)登錄了,提示錯誤信息 lblError.Text="此用戶(hù)已經(jīng)登錄"; return; }} list.Add(strUserId); Application.Add("GLOBAL_USER_LIST",list); 當然這里使用Cache等保存也可以。 接下來(lái)就是要在用戶(hù)退出的時(shí)候將此用戶(hù)從Application中去除,我們可以在Global.asax的Session_End事件中處理: voidSession_End(objectsender,EventArgse) { //在會(huì )話(huà)結束時(shí)運行的代碼。 //注意:只有在Web.config文件中的sessionstate模式設置為 //InProc時(shí),才會(huì )引發(fā)Session_End事件。 如果會(huì )話(huà)模式設置為StateServer //或SQLServer,則不會(huì )引發(fā)該事件。 stringstrUserId=Session["SESSION_USER"]asstring; ArrayListlist=Application.Get("GLOBAL_USER_LIST")asArrayList; if(strUserId!=null&&list!=null) { list.Remove(strUserId); Application.Add("GLOBAL_USER_LIST",list); } } 這些都沒(méi)有問(wèn)題,有問(wèn)題的就是當用戶(hù)直接點(diǎn)瀏覽器右上角的關(guān)閉按鈕時(shí)就有問(wèn)題了。因為直接關(guān)閉的話(huà),并不會(huì )立即觸發(fā)Session過(guò)期事件,也就是關(guān)閉瀏覽器后再來(lái)登錄就登不進(jìn)去了。 這里有兩種處理方式: 1、使用javascript方式 在每一個(gè)頁(yè)面中加入一段javascript代碼: functionwindow.onbeforeunload() { if(event.clientX>document.body .clientWidth&&event.clientY<0||event.altKey){ window.open("logout.aspx"); } } 由于onbeforeunload方法在瀏覽器關(guān)閉、刷新、頁(yè)面調轉等情況下都會(huì )被執行,所以需要判斷是點(diǎn)擊了關(guān)閉按鈕或是按下Alt+F4時(shí)才執行真正的關(guān)閉操作。 然后在logout.aspx的Page_Load中寫(xiě)和Session_End相同的方法,同時(shí)在logout.aspx中加入事件:onload="javascript:window.close()" 但是這樣還是有問(wèn)題,javascript在不同的瀏覽器中可能有不同的行為,還有就是當通過(guò)文件->關(guān)閉時(shí)沒(méi)有判斷到。 2、使用xmlhttp方法(這種方法測試下來(lái)沒(méi)有問(wèn)題) 在每個(gè)頁(yè)面中加入如下的javascript(這些javascript也可以寫(xiě)在共通里,每個(gè)頁(yè)面引入就可以了), varx=0; functionmyRefresh() { varhttpRequest= newActiveXObject("microsoft.xmlhttp"); httpRequest.open("GET","test.aspx",false); httpRequest.send(null); x++; if(x<60)//60次, //也就是Session真正的過(guò)期時(shí)間是30分鐘 { setTimeout("myRefresh()",30*1000);//30秒 } } myRefresh(); 在web.config中設置 以下是引用片段: "InProc"timeout="1"> test.aspx頁(yè)面就是一個(gè)空頁(yè)面, 只不過(guò)需要在Page_Load中加入: 以下是引用片段: Response.Expires=-1; 保證不使用緩存,每次都能調用到這個(gè)頁(yè)面。 |