author:咔咔
wechat:fangkangfk
惟一登陸:php
就是一個帳號只能在一臺設備登陸緩存
實現步驟:cookie
1.在用戶登陸的時候生成惟一token,本地緩存一份,服務端緩存一份工具
2.使用中間件進行判斷ui
在上一篇文章咱們將全部的層都放置到了根目錄的data中。this
建立OnlyLogin工具類spa
源碼:代理
<?php namespace data\util; use Cookie,Cache,Log,SC; /** * 惟一登陸的服務類 */ class OnlyLogin { /** * 驗證用戶是否惟一登陸 * @return array */ public function onlyCheck() { // 獲取本地的token $cookieToken = Cookie::get('TOKEN'.SC::getUserInfo('uid')); $cookieToken = Cookie::get('TOKEN'.SC::getUserInfo('uid')); // 獲取服務端緩存 $cacheToken = Cache::get('TOKEN'.SC::getUserInfo('uid')); // 當服務端或者本地的token爲空時容許登陸,只能夠有一我的登錄進去,因此無論是否異地 if(empty($cookieToken) || empty($cacheToken)){ Log::write('正常登錄,或者異地登陸'); return true; } if($cacheToken != $cookieToken){ Log::write('同時登陸了,你被T了'); return false; } Log::write('常規操做'); return true; } /** * 生成惟一key * @param $user_id 用戶id */ public function onlyRecord($user_id) { Log::write('你進來了'.$user_id); // 獲取已經建立好的token $token = $this->creatToken($user_id); // 本地設置token Cookie::set('TOKEN'.$user_id,$token); // 服務端設置token Cache::set('TOKEN'.$user_id,$token); } /** * 生成惟一的token * @param $user_id 用戶id * @return string */ public function creatToken($user_id) { //時間戳 $time = time(); //10到1000的隨機數 $nonce = mt_rand(10,1000); //按照字典序排序 $array = array($time,$nonce,'ONLY_USER_TOKEN',$user_id); sort($array); //轉爲字符串 $token = implode($array); return sha1($token); } /** * 清除用戶登陸的信息 */ public function clear() { } }
建立門面類進行靜態代理:日誌
配置門面類:code
建立中間鍵:
中間鍵配置:
日誌打印: