最初に 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; }
上記の確認方法から、確認コードの検証にはセッションが必要であることがわかります。有効になっていない場合は、マニュアルに従って初期化する必要があります。
アプリケーション app ディレクトリでグローバル ミドルウェア middleware.php ファイルを見つけ、コード \think\middleware\SessionInit を有効にします。 ::クラスは以下にコメントされています。
// 全局中间件定义文件 return [ // 全局请求缓存 // \think\middleware\CheckRequestCache::class, // 多语言加载 // \think\middleware\LoadLangPack::class, // Session初始化 \think\middleware\SessionInit::class ]
以上がTP6認証コード認証が失敗する原因と解決策の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。