PHPでThinkPhpフレームワークのトークンを使用する方法

PHPz
リリース: 2023-05-26 14:14:25
転載
1912 人が閲覧しました

1. ThinkPhp フレームワークでのトークンの使用

#1. まず、データベースの users テーブルに token と time_out の 2 つのフィールドを追加します

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. トークン

トークンの概念は、クライアントがサーバーに頻繁にデータを要求し、サーバーがユーザー名とパスワードをデータベースに頻繁に照会することです。ユーザー名とパスワードが正しいかどうかを確認し、「いいえ」と対応するプロンプトを表示するこのコンテキストで、トークンが登場しました。

以上がPHPでThinkPhpフレームワークのトークンを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:yisu.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート