ThinkPhp5 实现token登陆

1: 首先在数据库的 users 表中添加两个字段

    1): token  //token 用于存储用户的 token

    2): time_out  //time_out 用于设置用户 token 的过期时间

首先创建函数: checkToekn($token)

函数用于检验 token 是否存在, 并且更新 token

public function checkToken($token)
    {
        $user = new appindexmodelUsers();
        $res = $user->field('time_out')->where('token', $token)->select();
 
        if (!empty($res)) {
            //dump(time() - $res[0]['time_out']);
            if (time() - $res[0]['time_out'] > 0) {
     
                return 90003; //token长时间未使用而过期,需重新登陆
            }
            $new_time_out = time() + 604800; //604800是七天
            $res = $user->isUpdate(true)
                ->where('token', $token)
                ->update(['time_out' => $new_time_out]);
            if ($res) {
     
                return 90001; //token验证成功,time_out刷新成功,可以获取接口信息
            }
        }
 
        return 90002; //token错误验证失败
    }

创建函数: douserLogin($username,$password)

用于验证用户名密码, 并登陆, 返回 token 信息

public function douserLogin()    {        
    $user = new appindexmodelUsers();        
    $userisset = $user->where('username', $username)->find();        
    if ($userisset == null) {            
        return json_decode('{"user":"' . $username . '","code":"400","msg":"用户不存在"}');        
    } else {            
        $userpsisset = $user->where('username', $username)->where('password', sha1(md5($password)))->find();             
        if ($userpsisset == null) {                
            return json_decode('{"user":"' . $username . '","code":"401","msg":"密码错误"}');            
        } else {                
            //session('user', $username);                
            $token = $this->makeToken();                
            $time_out = strtotime("+7 days");                
            $userinfo = ['time_out' => $new_time_out,                    
            'token' => $token];                
            $res = $user->isUpdate(true)->where('username', $username)->update($userinfo);                
                if ($res) {                    
                    return json_decode('{"user":"' . $username . '","toekn":'.$token.' "code":"0","msg":"登录成功"}');                
                }            
            }        
        }    
}

创建函数: makeToekn()

创建 token

   private function makeToken()    {         
       $str = md5(uniqid(md5(microtime(true)), true)); //生成一个不会重复的字符串        
       $str = sha1($str); //加密        
       return $str;    
   }

    

使用的时候, 在需要验证的地方加上如下内容即可判断是否登陆

$login = new appindexcontrollerLogin;
$res = $login->checkToken($token);
if($res ==90001){
    echo 'ok';
}else if($res == 90002){
    echo 'err';
}else if($res == 90003){
    echo 'relogin';
}

测试结果

前台反馈

错误 token

超时 token

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值