1. ThinkPhp 프레임워크에서 토큰 사용
1. 먼저 데이터베이스의 사용자 테이블에 token 및 time_out 두 필드를 추가합니다.
token은 사용자 토큰을 저장하는 데 사용됩니다.
time_out은 사용자 토큰 만료 시간
2. 함수 생성
checkToekn($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)
를 만듭니다.
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":"登录成功"}'); } } } }
2. Token의 개념
Token은 클라이언트가 서버에 자주 데이터를 요청하는 것이며, 서버는 자주 데이터베이스에 가서 사용자 이름과 비밀번호를 쿼리하여 사용자 이름과 비밀번호가 맞는지 확인하고, 이에 상응하는 프롬프트를 만드십시오. 그런 다음 토큰이 탄생했습니다.
위 내용은 PHP에서 ThinkPhp 프레임워크의 토큰을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!