最初に Composer を使用して think-captcha 拡張機能パッケージをインストールします:
composer require topthink/think-captcha
コントローラーの紹介
use think\captcha\facade\Captcha;
確認コードの生成
public function verify() { return Captcha::create(); }
確認コードの確認
if( !Captcha::check($vercode)) { return json(['code'=>1001, 'msg'=>'验证码错误'); }
確認方法
/** * 验证验证码是否正确 * @access public * @param string $code 用户验证码 * @return bool 用户验证码是否正确 */ public function check(string $code): bool { if (!$this->session->has('captcha')) { return false; } $key = $this->session->get('captcha.key'); $code = mb_strtolower($code, 'UTF-8'); $res = password_verify($code, $key); if ($res) { $this->session->delete('captcha'); } return $res; }
上記の確認方法から、検証コードの検証にはセッションが必要であることがわかり、デフォルトでは Thinkphp6 が有効になっていないため、マニュアルに従って初期化する必要があります。アプリケーションのアプリケーション ディレクトリ ファイル middleware.php のグローバル ミドル、以下にコメントされているコードをオンにするだけです\think\middleware\SessionInit::class
// 全局中间件定义文件 return [ // 全局请求缓存 // \think\middleware\CheckRequestCache::class, // 多语言加载 // \think\middleware\LoadLangPack::class, // Session初始化 \think\middleware\SessionInit::class ];
以上が見なければならないものだ! TP6認証コード認証が失敗する原因と解決策の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。