這篇“PHP中ThinkPhp框架的token怎么使用”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“PHP中ThinkPhp框架的token怎么使用”文章吧。
一、token在ThinkPhp框架的使用
1. 首先在數據庫的 users 表中添加兩個字段token、time_out
token 用于存儲用戶的 token
time_out 用于設置用戶 token 的過期時間
2.創建函數
checkToekn($token)
函數用于檢驗 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長時間未使用而過期,需重新登陸
}
$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錯誤驗證失敗
}3.創建函數
douserLogin($username,$password)
用于驗證用戶名密碼, 并登陸, 返回 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":"密碼錯誤"}');
} 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":"登錄成功"}');
}
}
}
}二、Token的概念
token是客戶端頻繁向服務器端請求數據,服務器頻繁的去數據庫查詢用戶名和密碼判斷用戶名和密碼正確與否,并作出相應的提示,在這樣的背景下,token便應運而生了。
以上就是關于“PHP中ThinkPhp框架的token怎么使用”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。