當我們的QQ在異地登入的時候會有訊息提醒,對於安全性要求比較高的web網站,特別是後台管理,有時候需要甄別自己的帳號是否被盜或是否有另一個人此刻登陸了在進行後台操作,這些都會很不安全,為了避免兩個人同時登入同時操作,可以強制下線一個帳號。
透過IP判斷當然是不行的,因為IP是隨時會在某一個網段內變化的,但是有一個機制,恰巧可以解決這個,那就是session,只要使用同一個瀏覽器訪問網站,瀏覽器不關閉每個來訪者的session_id是不變的,這也正是解決這個問題所需要的。
以TP框架搭建的網站後台為例,想法如下:
(1)資料庫使用者表
在user表中,增加一個欄位`session_id` varchar(32)
,用來存放登入之後的session_id。
(2)用戶登入
用戶登錄,就是正常的判斷帳號密碼以及驗證碼,當這些都驗證通過的時候,取出當前的session_id存入資料庫user表中。
M('user')->where(array('id'=>$_SESSION['uid']))->save(array('session_id'=>session_id()));
(3)解決異地登入問題
對於後台操作,為了便於驗證和操作安全,基本上都會先創建一個基礎控制器BaseController,然後後台的其他操作控制器都會繼承這個基礎控制器。對於後台的每一步操作之前,使用者狀態的偵測都放在BaseController控制器的初始化_initialize()
方法中。
現在在_initialize()
方法中,除了驗證使用者登入狀態是否被鎖定等等,還要取出本機session_id和存放在user表中的session_id進行比對,如果對不上那麼表名帳號在異地有登陸,這時候可以迫使強制下線,退回到登入頁面。
$user = M('user')->where(array('id'=>$_SESSION['uid']))->find(); $session_id = session_id(); if($user['session_id'] != $session_id){ session_destroy(); $this->error('您的账号在其他地方登录,您已经被强制下线', U('login')); }
當然也可以取得到異地登陸的IP,給予提醒:
##相關推薦:以上是PHP實作使用者異地登入提醒功能的程式碼分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!