【TP5.1】惟一登陸

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

 

建立中間鍵:

中間鍵配置:

 

日誌打印:

 

相關文章
相關標籤/搜索