ThinkPHP est un framework de développement PHP très populaire. Il fournit de nombreuses fonctions et outils pratiques, permettant aux développeurs de développer des applications Web plus rapidement et plus efficacement. Il comprend une fonction de code de vérification, qui peut empêcher efficacement l'enregistrement et la connexion malveillants par des robots. Cependant, nous rencontrons parfois le problème que le code de vérification ne s’affiche pas. Cet article expliquera ce problème en détail.
Dans ThinkPHP, l'image du code de vérification est stockée par défaut dans le répertoire de vérification sous le répertoire d'exécution. Si le chemin de stockage est incorrect, l'image du code de vérification ne le sera pas. affiché.
Tout d'abord, vous devez vérifier si le chemin du code de vérification dans le code est correct. Dans l'implémentation du code de vérification de ThinkPHP, vous pouvez spécifier le chemin pour générer l'image du code de vérification en définissant le paramètre verify_img. Le code spécifique est le suivant :
$config = [ 'reset' => false, 'useCurve' => false, 'useNoise' => false, 'length' => 4, 'fontSize' => 25, 'imageH' => 40, 'imageW' => 160, 'fontttf' => '5.ttf', 'bg' => [243, 251, 254], 'reset' => false, 'codeSet' => '0123456789', ]; $verify = new \think\captcha\Captcha($config); return $verify->entry();
Comme vous pouvez le voir, le chemin pour générer l'image du code de vérification n'est pas spécifié dans. le code ci-dessus. La valeur par défaut est stockée dans le répertoire runtime/verify. Par conséquent, si l'image de votre code de vérification ne s'affiche pas, vous pouvez vérifier si le chemin existe et s'il dispose des autorisations de lecture et d'écriture.
Lorsque nous accédons à l'adresse URL générée par le code de vérification, le code de vérification peut ne pas être généré avec succès pour une raison quelconque. À ce stade, vous pouvez ajouter des informations de débogage au code qui obtient l'image du code de vérification pour voir s'il y a une sortie. Voici un exemple :
$verify = new \think\captcha\Captcha(); if (!$verify->check($code, $id)){ return '验证码错误!'; } else { echo '验证码正确'; }
Dans le code ci-dessus, nous déterminons si le code de vérification est correct en appelant la méthode check de la classe Captcha. Si le code de vérification est correct, « Le code de vérification est correct » sera affiché, sinon « Le code de vérification est erroné ! » sera affiché. Ces informations de débogage peuvent nous aider à confirmer si le code de vérification est généré avec succès.
Dans ThinkPHP, l'adresse URL pour générer le code de vérification est renvoyée par la méthode de saisie de la classe Captcha. Si nous combinons manuellement les adresses URL dans le code, cela peut entraîner des chemins d'accès incorrects. Voici un exemple :
$src = url('/captcha');
Dans le code ci-dessus, nous avons ajouté manuellement un chemin vers /captcha. Bien sûr, ce chemin n'existe pas. La bonne façon de l'utiliser est de générer l'adresse URL du code de vérification via la méthode de saisie de la classe Captcha, par exemple :
$verify = new \think\captcha\Captcha(); return $verify->entry();
Dans le code ci-dessus, nous renvoyons directement l'adresse URL renvoyée par la méthode de saisie de la classe Captcha, ce qui peut garantir l'exactitude du chemin d'accès.
Résumé :
Ce qui précède est l'analyse et la solution du problème que le code de vérification n'affiche pas dans le framework ThinkPHP. Généralement, ce problème est dû à un chemin de génération d'image de code de vérification incorrect, à l'échec de l'appel de la fonction de génération d'image de code de vérification ou à un chemin d'accès incorrect. Nous pouvons trouver et résoudre des problèmes en inspectant et en déboguant le code.
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!