|
Trouver une ressource
Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !
PROTÉGER LES FORMULAIRES DES ROBOTS GRÂCE A UNE IMAGE.
Information sur la source
Description
C'est un script qui permet de créer une image avec des chiffres et des lettres dynamiquement pour vérifier que c'est bien un humain qui écrit ;).
Vous en avez surment déjà vu, je crois que pour l'inscription au forum IPB y en a une. Bon d'abors renseigné-vous, vous devez posséder la librairie GD, peu d'Hébergeur gratuit en dispose, pour savoir sa faites un phpinfo().
10/02: Voila je l'ai amélioré en suivant vos conseil, les changements sont: une police perso, le création aleatoires de points de différentes couleurs, la création de 2 lignes verte qui se place aléatoirement, le code qui se décale horizontalement et verticalement aléatoirement (:d ) et l'amelioraiton de la page de validation.
Enjoy !
Merci pour vos remarque, faites en autant cette fois ci ;)
Source
- <?PHP
- #########
- # image.php#
- #########
-
- session_start(); //on demarre les sessions
-
- $image = imagecreate(100,25); //On créer une image de 100 px sur 25
-
- $gris = imagecolorallocate($image,230,230,230); //gris
-
- $noir = imagecolorallocate($image,0,0,0); //noir
-
- $bleu = imagecolorallocate($image,0,0,255); //bleu
-
- $rouge = imagecolorallocate($image,255,0,0); //rouge
-
- $vert = imagecolorallocate($image,0,255,0); //vert
-
- imagefill($image,0,0,$gris); //on la rempli de gris
-
- $nbr = rand(235684,999999); //on génére un nombre
-
- $md5 = md5($nbr); //on le code en md5
-
- $code = substr($md5,0,8); //on le limite a 8 caracteres
-
- $_SESSION['code'] = $code;
-
- $font = imageloadfont("8x13iso.gdf"); //on insere un police
-
- $x = mt_rand(15,20);
- $y = mt_rand(0,7);
-
- imagestring($image,$font,$x,$y,$code,$noir); //on écrit sur l'image
-
- $pointb = 1;
-
- while($pointb <= 50) // Boucle pour faire 50 point bleu
- {
- $x = mt_rand(0,100);
- $y = mt_rand(0,25);
- ImageSetPixel($image, $x, $y, $bleu);
- $pointb++;
- }
-
- $pointn = 1;
-
- while($pointn <= 50) // Boucle pour faire 50 point noir
- {
- $x = mt_rand(0,100);
- $y = mt_rand(0,25);
- ImageSetPixel($image, $x, $y, $noir);
- $pointn++;
- }
-
-
- $pointr = 1;
-
- while($pointr <= 50) // Boucle pour faire 50 point rouge
- {
- $x = mt_rand(0,100);
- $y = mt_rand(0,25);
- ImageSetPixel($image, $x, $y, $rouge);
- $pointr++;
- }
-
- $ligne = 1;
-
- while($ligne <= 2) //Tracer 2 lignes
- {
- $x1 = mt_rand(0,100);
- $y1 = mt_rand(0,25);
- $x2 = mt_rand(0,100);
- $y2 = mt_rand(0,25);
- ImageLine($image, $x1, $y1, $x2, $y2, $vert);
- $ligne++;
- }
-
-
- imagepng($image); //on dessine l'image
-
- ?>
-
- form.html
-
- <html>
- <head>
- </head>
-
- <body>
- <div align="center">
- <img src="image.php"/>
-
- <form action="valide.php" method="post" name="code">
- Tapez ce qu'il y a sur l'image au dessus: <input name="code" type="text">
- <input name="Envoyer" type="submit" value="Envoyer">
- </form>
- </div>
- </body>
- </html>
-
- valide.php
-
- <?
- //valide.php
-
- session_start(); //On demarre la session.
-
- $code = $_SESSION['code'];
- //On simplifie les variables.
- $code1 = $_POST['code'];
-
- if(isset($code1) && !empty($code1))
- {
- if($code == $code1) //On test si le code qui a été tapé correspond au vrai code
- {
- echo "code bon !!"; //Si oui on dit qu'il est bon
- }
- else
- {
- echo "code mauvais"; //Sinon on dit qu'il est mauvais.
- }
- }
- else
- {
- echo "Vous avez accédé a cette page illégalement où vous n'avez tapé aucun code, réesayez.";
- }
-
- ?>
<?PHP
#########
# image.php#
#########
session_start(); //on demarre les sessions
$image = imagecreate(100,25); //On créer une image de 100 px sur 25
$gris = imagecolorallocate($image,230,230,230); //gris
$noir = imagecolorallocate($image,0,0,0); //noir
$bleu = imagecolorallocate($image,0,0,255); //bleu
$rouge = imagecolorallocate($image,255,0,0); //rouge
$vert = imagecolorallocate($image,0,255,0); //vert
imagefill($image,0,0,$gris); //on la rempli de gris
$nbr = rand(235684,999999); //on génére un nombre
$md5 = md5($nbr); //on le code en md5
$code = substr($md5,0,8); //on le limite a 8 caracteres
$_SESSION['code'] = $code;
$font = imageloadfont("8x13iso.gdf"); //on insere un police
$x = mt_rand(15,20);
$y = mt_rand(0,7);
imagestring($image,$font,$x,$y,$code,$noir); //on écrit sur l'image
$pointb = 1;
while($pointb <= 50) // Boucle pour faire 50 point bleu
{
$x = mt_rand(0,100);
$y = mt_rand(0,25);
ImageSetPixel($image, $x, $y, $bleu);
$pointb++;
}
$pointn = 1;
while($pointn <= 50) // Boucle pour faire 50 point noir
{
$x = mt_rand(0,100);
$y = mt_rand(0,25);
ImageSetPixel($image, $x, $y, $noir);
$pointn++;
}
$pointr = 1;
while($pointr <= 50) // Boucle pour faire 50 point rouge
{
$x = mt_rand(0,100);
$y = mt_rand(0,25);
ImageSetPixel($image, $x, $y, $rouge);
$pointr++;
}
$ligne = 1;
while($ligne <= 2) //Tracer 2 lignes
{
$x1 = mt_rand(0,100);
$y1 = mt_rand(0,25);
$x2 = mt_rand(0,100);
$y2 = mt_rand(0,25);
ImageLine($image, $x1, $y1, $x2, $y2, $vert);
$ligne++;
}
imagepng($image); //on dessine l'image
?>
form.html
<html>
<head>
</head>
<body>
<div align="center">
<img src="image.php"/>
<form action="valide.php" method="post" name="code">
Tapez ce qu'il y a sur l'image au dessus: <input name="code" type="text">
<input name="Envoyer" type="submit" value="Envoyer">
</form>
</div>
</body>
</html>
valide.php
<?
//valide.php
session_start(); //On demarre la session.
$code = $_SESSION['code'];
//On simplifie les variables.
$code1 = $_POST['code'];
if(isset($code1) && !empty($code1))
{
if($code == $code1) //On test si le code qui a été tapé correspond au vrai code
{
echo "code bon !!"; //Si oui on dit qu'il est bon
}
else
{
echo "code mauvais"; //Sinon on dit qu'il est mauvais.
}
}
else
{
echo "Vous avez accédé a cette page illégalement où vous n'avez tapé aucun code, réesayez.";
}
?>
Conclusion
Ce code n'est pas infaillible ;) il est sencée être le plus simple possible.
Fichier Zip
Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !
Télécharger le zip
Historique
- 10 février 2005 14:22:46 :
- 10/02: Voila je l'ai amélioré en suivant vos conseil, les changements sont: une police perso, le création aleatoires de points de différentes couleurs, la création de 2 lignes verte qui se place aléatoirement, le code qui se décale horizontalement et verticalement aléatoirement (:d ) et l'amelioraiton de la page de validation.
Enjoy !
Merci pour vos remarque, faites en autant cette fois ci ;)
Sources de la même categorie
Commentaires et avis
|
|