Maison cadre php PensezPHP Le code de vérification thinkphp5 a échoué

Le code de vérification thinkphp5 a échoué

May 26, 2023 am 10:53 AM

ThinkPHP5 est un framework PHP développé sur la base du modèle MVC. Il est facile à utiliser et puissant, et est largement utilisé dans le développement d'applications Web au niveau de l'entreprise.

La fonction de code de vérification est l'une des fonctions de vérification de sécurité les plus couramment utilisées, mais dans le processus de développement réel, de nombreuses personnes rencontreront des situations dans lesquelles le code de vérification ne prend pas effet ou la vérification échoue. Analysons les causes possibles et les solutions à ces situations.

  1. Le problème que le code de vérification ne s'affiche pas

Tout d'abord, vous devez vérifier si le plug-in du code de vérification a été correctement introduit.

Dans ThinkPHP5, le plug-in de code de vérification se trouve dans le répertoire thinkcaptcha et peut être introduit via le code suivant :

use thinkcaptchaCaptcha;

//显示验证码
public function verify(){
    $captcha = new Captcha();
    return $captcha->entry();
}
Copier après la connexion

Ajoutez le code de vérification au code HTML dans le frontend :

<img src="{:captcha_src()}" alt="captcha" onclick="this.src='{:captcha_src()}?t='+Math.random();">
Copier après la connexion

Si le code de vérification ne parvient toujours pas s'affiche normalement, il peut s'agir d'un problème de cache, vous pouvez vider le cache du navigateur ou essayer d'utiliser un autre navigateur pour tester.

  1. Le problème de l'échec de la vérification du code de vérification

Si vous vous assurez que le code de vérification a été affiché correctement, mais qu'il provoque une erreur de code de vérification lors de la vérification, vous devez vérifier les points suivants :

2.1 Est-ce le nom du paramètre de formulaire soumis lors de la vérification du code de vérification ? Correct

Par défaut, le plug-in de code de vérification de ThinkPHP5 générera un paramètre POST nommé captcha pour stocker la valeur du code de vérification. Si la vérification échoue, un message d'erreur au format JSON est nécessaire. à restituer. Par conséquent, lors de la vérification, vous devez vous assurer que le nom du paramètre soumis dans le formulaire est également captcha, par exemple :

//验证验证码
if (!captcha_check(input('post.captcha'))) {
    return json([
        'status' => '0',
        'msg' => '验证码错误!'
    ]);
}
Copier après la connexion

2.2 Le code de vérification n'est pas sensible à la casse

Le code de vérification est sensible à la casse par défaut, donc lors de la vérification le code de vérification, vous devez vous assurer que le code de vérification que vous entrez correspond exactement au code de vérification que vous avez généré. Si vous souhaitez que le code de vérification ne soit pas sensible à la casse, vous pouvez ajouter des paramètres lors de l'appel de la méthode captcha(), par exemple :

$captcha = new Captcha(['useZh' => false, 'useImgBg' => true, 'fontSize' => 20, 'useNoise' => true, 'length' => 4, 'useCurve' => false, 'fontttf' => '4.ttf', 'bg' => [151, 232, 66], 'reset' => true, 'codeSet' => '0123456789', 'expire' => 300, 'zhSet' => '']);
Copier après la connexion

Dans les paramètres ci-dessus, le paramètre useZh est utilisé pour afficher le code de vérification chinois, et le paramètre useImgBg et les paramètres useNoise sont utilisés pour générer l'image d'arrière-plan et les points de bruit, le paramètre length indique la longueur du code de vérification, le paramètre codeSet définit le jeu de caractères du code de vérification et le paramètre expire définit le délai d'expiration du code de vérification. Notez que zhSet est défini ici sur une chaîne vide, ce qui signifie que les codes de vérification chinois ne sont pas activés.

2.3 Code de vérification et soumission du formulaire sur la même page

Si le code de vérification et la soumission du formulaire se trouvent sur la même page et que l'opération de vérification doit être soumise via Ajax, le code de vérification peut ne pas être vérifié avec succès en raison de croisements. domaine, échec de session, etc. À ce stade, Access-Control-Allow-Origin doit être défini dans un environnement inter-domaines, par exemple :

header('Access-Control-Allow-Origin: *');
Copier après la connexion

Vous devez également vous assurer que la session est ignorée. Vous pouvez l'ajouter avant session_start() :

.
header('P3P: CP=CAO PSA OUR');
session_start();
Copier après la connexion

Vous pouvez lire attentivement les informations pertinentes dans la section du manuel ThinkPHP5 du plug-in de code de vérification, ou rechercher des questions connexes dans le forum officiel pour obtenir plus de solutions et de conseils à ce problème.

En bref, lors de la conception et de la mise en œuvre de codes de vérification, il est nécessaire de faire des compromis et des équilibres entre la sécurité et l'expérience utilisateur, de suivre des principes de conception communs et les meilleures pratiques, et d'utiliser des composants et des bibliothèques tiers vérifiés pour garantir la fiabilité et validité du code de vérification.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment puis-je utiliser ThinkPHP pour créer des applications de ligne de commande? Comment puis-je utiliser ThinkPHP pour créer des applications de ligne de commande? Mar 12, 2025 pm 05:48 PM

Cet article montre la création d'applications de ligne de commande (CLI) en utilisant les capacités CLI de ThinkPhp. Il met l'accent sur les meilleures pratiques telles que la conception modulaire, l'injection de dépendance et la gestion des erreurs robuste, tout en mettant en évidence les pièges communs tels que INSU

Quelles sont les principales considérations pour utiliser ThinkPhp dans une architecture sans serveur? Quelles sont les principales considérations pour utiliser ThinkPhp dans une architecture sans serveur? Mar 18, 2025 pm 04:54 PM

L'article traite des considérations clés pour l'utilisation de ThinkPHP dans des architectures sans serveur, en se concentrant sur l'optimisation des performances, la conception sans état et la sécurité. Il met en évidence des avantages tels que la rentabilité et l'évolutivité, mais relève également des défis

Quelles sont les caractéristiques avancées du conteneur d'injection de dépendance de ThinkPhp? Quelles sont les caractéristiques avancées du conteneur d'injection de dépendance de ThinkPhp? Mar 18, 2025 pm 04:50 PM

Le conteneur IOC de ThinkPhp propose des fonctionnalités avancées comme le chargement paresseux, la liaison contextuelle et l'injection de méthode pour une gestion efficace des dépendances dans les applications PHP. COMMANDE CHARACTER: 159

Comment puis-je prévenir les vulnérabilités d'injection SQL dans ThinkPhp? Comment puis-je prévenir les vulnérabilités d'injection SQL dans ThinkPhp? Mar 14, 2025 pm 01:18 PM

L'article discute de la prévention des vulnérabilités d'injection SQL dans ThinkPhP à travers des requêtes paramétrées, en évitant le SQL brut, en utilisant ORM, des mises à jour régulières et une bonne gestion des erreurs. Il couvre également les meilleures pratiques pour sécuriser les requêtes de base de données et le validat

Comment construire un système de file d'attente de tâches distribué avec ThinkPhp et RabbitMQ? Comment construire un système de file d'attente de tâches distribué avec ThinkPhp et RabbitMQ? Mar 18, 2025 pm 04:45 PM

L'article décrit la création d'un système de file d'attente de tâches distribué à l'aide de ThinkPhp et RabbitMQ, en se concentrant sur l'installation, la configuration, la gestion des tâches et l'évolutivité. Les problèmes clés incluent assurer la haute disponibilité, éviter les pièges communs comme Imprope

Quelles sont les principales caractéristiques du cadre de test intégré de ThinkPHP? Quelles sont les principales caractéristiques du cadre de test intégré de ThinkPHP? Mar 18, 2025 pm 05:01 PM

L'article traite du cadre de test intégré de ThinkPhP, mettant en évidence ses principales fonctionnalités telles que les tests d'unité et d'intégration, et comment il améliore la fiabilité des applications grâce à la détection précoce des bogues et à une meilleure qualité de code.

Quelles sont les principales différences entre ThinkPhp 5 et ThinkPhp 6, et quand utiliser chacun? Quelles sont les principales différences entre ThinkPhp 5 et ThinkPhp 6, et quand utiliser chacun? Mar 14, 2025 pm 01:30 PM

L'article traite des différences clés entre ThinkPHP 5 et 6, en se concentrant sur l'architecture, les fonctionnalités, les performances et l'adéquation pour les mises à niveau héritées. ThinkPhp 5 est recommandé pour les projets traditionnels et les systèmes hérités, tandis que ThinkPhp 6 convient au nouveau PR

Comment implémenter la découverte de services et l'équilibrage de chargement dans les microservices ThinkPHP? Comment implémenter la découverte de services et l'équilibrage de chargement dans les microservices ThinkPHP? Mar 18, 2025 pm 04:51 PM

L'article discute de la mise en œuvre de la découverte de services et de l'équilibrage des charges dans les microservices ThinkPHP, en se concentrant sur la configuration, les meilleures pratiques, les méthodes d'intégration et les outils recommandés. [159 caractères]

See all articles