前幾天用thinkphp5做項(xiàng)目需要用到token登陸,在此整理了一下分享給大家,需要的可以研究研究。
一、首先在數(shù)據(jù)庫的 users 表中添加兩個(gè)字段
1、token
2、time_outtoken 【用于存儲(chǔ)用戶的 tokentime_out 用于設(shè)置用戶 token 的過期時(shí)間首先創(chuàng)建函數(shù): checkToekn($token)函數(shù)用于檢驗(yàn) token 是否存在, 并且更新 token】
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長(zhǎng)時(shí)間未使用而過期,需重新登陸 } $new_time_out = time() + 604800; //604800是七天 $res = $user->isUpdate(true) ->where('token', $token) ->update(['time_out' => $new_time_out]); if ($res) { return 90001; //token驗(yàn)證成功,time_out刷新成功,可以獲取接口信息 } } return 90002; //token錯(cuò)誤驗(yàn)證失敗 }
創(chuàng)建函數(shù):douserLogin($username,$password)用于驗(yàn)證用戶名密碼, 并登陸, 返回 token 信息
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":"密碼錯(cuò)誤"}'); } 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":"登錄成功"}'); } } } }
創(chuàng)建函數(shù):makeToekn()創(chuàng)建 token
private function makeToken() { $str = md5(uniqid(md5(microtime(true)), true)); //生成一個(gè)不會(huì)重復(fù)的字符串 $str = sha1($str); //加密 return $str; }
使用的時(shí)候,在需要驗(yàn)證的地方加上如下內(nèi)容即可判斷是否登陸
$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'; }
這樣基本上就可以了,希望對(duì)大家有所幫助。