【TP5.1】唯一登录

版权声明:咔咔 来自https://blog.csdn.net/fangkang7 https://blog.csdn.net/fangkang7/article/details/83587724

author:咔咔

wechat:fangkangfk

唯一登录:

就是一个账号只能在一台设备登录

实现步骤:

1.在用户登录的时候生成唯一token,本地缓存一份,服务端缓存一份

2.使用中间件进行判断

在上一篇文章我们将所有的层都放置到了根目录的data中。

创建OnlyLogin工具类

 源码:

<?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()
    {

    }
}


创建门面类进行静态代理:

 

配置门面类:

 

创建中间键:

中间键配置:

 

日志打印:

 

猜你喜欢

转载自blog.csdn.net/fangkang7/article/details/83587724
今日推荐