Maison > Article > développement back-end > A voir absolument ! Raisons et solutions de l'échec de la vérification du code de vérification TP6
Utilisez d'abord Composer pour installer le package d'extension think-captcha :
composer require topthink/think-captcha
Introduction au contrôleur
use think\captcha\facade\Captcha;
Générer le code de vérification
public function verify() { return Captcha::create(); }
Vérifier le code de vérification
if( !Captcha::check($vercode)) { return json(['code'=>1001, 'msg'=>'验证码错误'); }
Vérifier la méthode
/** * 验证验证码是否正确 * @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; }
Il ressort de la méthode de vérification ci-dessus que la vérification du code de vérification nécessite une session et que Thinkphp6 n'est pas activé par défaut. Il doit être initialisé conformément au manuel
Trouver le global. milieu dans le répertoire de l'application Fichier middleware.php, activez simplement le code commenté ci-dessous thinkmiddlewareSessionInit::class
// 全局中间件定义文件 return [ // 全局请求缓存 // \think\middleware\CheckRequestCache::class, // 多语言加载 // \think\middleware\LoadLangPack::class, // Session初始化 \think\middleware\SessionInit::class ];
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!