【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

 

建立中间键:

中间键配置:

 

日志打印:

 

相关文章
相关标签/搜索