ThinkPhp5 实现token登陆的学习笔记分享

 4843

前几天用thinkphp5做项目需要用到token登陆,在此整理了一下分享给大家,需要的可以研究研究。

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

1、token

2、time_outtoken 【用于存储用户的 tokentime_out 用于设置用户 token 的过期时间首先创建函数: checkToekn($token)函数用于检验 token 是否存在, 并且更新 token】

  1. public function checkToken($token)
  2. {
  3.     $user = new \app\index\model\Users();
  4.     $res = $user->field('time_out')->where('token', $token)->select();
  5.  
  6.     if (!empty($res)) {
  7.         //dump(time() - $res[0]['time_out']);
  8.         if (time() - $res[0]['time_out'] > 0) {
  9.   
  10.             return 90003; //token长时间未使用而过期,需重新登陆
  11.         }
  12.         $new_time_out = time() + 604800; //604800是七天
  13.         $res = $user->isUpdate(true)
  14.             ->where('token', $token)
  15.             ->update(['time_out' => $new_time_out]);
  16.         if ($res) {
  17.   
  18.             return 90001; //token验证成功,time_out刷新成功,可以获取接口信息
  19.         }
  20.     }
  21.  
  22.     return 90002; //token错误验证失败
  23. }

创建函数:douserLogin($username,$password)用于验证用户名密码, 并登陆, 返回 token 信息

  1. public function douserLogin()
  2. {
  3.     $user = new \app\index\model\Users();
  4.     $userisset = $user->where('username', $username)->find();
  5.     if ($userisset == null) {
  6.         return json_decode('{"user":"' . $username . '","code":"400","msg":"用户不存在"}');
  7.     } else {
  8.         $userpsisset = $user
  9.             ->where('username', $username)
  10.             ->where('password', sha1(md5($password)))->find();
  11.         if ($userpsisset == null) {
  12.             return json_decode('{"user":"' . $username . '","code":"401","msg":"密码错误"}');
  13.         } else {
  14.             //session('user', $username);
  15.             $token = $this->makeToken();
  16.             $time_out = strtotime("+7 days");
  17.             $userinfo = ['time_out' => $new_time_out,
  18.                 'token' => $token];
  19.             $res = $user->isUpdate(true)
  20.                 ->where('username', $username)
  21.                 ->update($userinfo);
  22.             if ($res) {
  23.                 return json_decode('{"user":"' . $username . '","toekn":'.$token.' "code":"0","msg":"登录成功"}');
  24.             }
  25.         }
  26.     }
  27. }

创建函数:makeToekn()创建 token

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

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

  1. $login = new \app\index\controller\Login;
  2. $res = $login->checkToken($token);
  3. if($res ==90001){
  4.     echo 'ok';
  5. }else if($res == 90002){
  6.     echo 'err';
  7. }else if($res == 90003){
  8.     echo 'relogin';
  9. }

这样基本上就可以了,希望对大家有所帮助。




本文网址:https://www.zztuku.com/detail-7679.html
站长图库 - ThinkPhp5 实现token登陆的学习笔记分享
申明:如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐