吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 5741|回复: 3
收起左侧

[其他转载] ThinkPhp5 实现token登陆

[复制链接]
jiujiukeji 发表于 2019-4-23 15:31
本帖最后由 jiujiukeji 于 2019-4-23 15:38 编辑

1: 首先在数据库的 users 表中添加两个字段
1): token
2): time_outtoken 用于存储用户的 tokentime_out 用于设置用户 token 的过期时间首先创建函数: checkToekn($token)函数用于检验 token 是否存在, 并且更新 token
[PHP] 纯文本查看 复制代码
    public function checkToken($token)
    {
        $user = new \app\index\model\Users();
        $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 信息
[PHP] 纯文本查看 复制代码
public function douserLogin()
    {
        $user = new \app\index\model\Users();
        $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
[PHP] 纯文本查看 复制代码
 private function makeToken()
    {
 
        $str = md5(uniqid(md5(microtime(true)), true)); //生成一个不会重复的字符串
        $str = sha1($str); //加密
        return $str;
    }
   
使用的时候, 在需要验证的地方加上如下内容即可判断是否登陆
[PHP] 纯文本查看 复制代码
$login = new \app\index\controller\Login;
$res = $login->checkToken($token);
if($res ==90001){
echo 'ok';
}
else if($res == 90002){
echo 'err';
}
else if($res == 90003){
echo 'relogin';
}

测试结果
前台反馈
201805031525331866220565.png
错误 token
201805031525331912895296.png
超时 token
201805031525331938909876.png

免费评分

参与人数 3吾爱币 +6 热心值 +3 收起 理由
TMF4CK + 1 + 1 用心讨论,共获提升!
炫金呀 + 2 + 1 用心讨论,共获提升!
苏紫方璇 + 3 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

a634085832 发表于 2019-4-23 15:59
Token一般不会存在数据库,软数据,存Session,设置过期时间就行了,不然高访问量后,数据库查询慢
 楼主| jiujiukeji 发表于 2019-4-23 16:03
a634085832 发表于 2019-4-23 15:59
Token一般不会存在数据库,软数据,存Session,设置过期时间就行了,不然高访问量后,数据库查询慢

存哪都是自己的手段   我只是举例
九炎 发表于 2019-4-23 17:30
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-16 07:44

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表