Controllo antispam in php

Quante volte avreste voluto avere un bellissimo e professionale codice antispam nei vostri scripts in php?

Ecco a voi come fare.

Svilupperemo una classe e useremo le librerie gd del nostro fidato linguaggio.

1 ) Create una pagina di nome antispam.php


[php]

session_start(); //Avviamo la sessione

class CaptchaSecurityImages { //Creazione della classe


var $font = ’monofont.ttf’;


function generateCode($characters) {

/* list all possible characters, similar looking characters and vowels have been removed */

$possible = ’23456789bcdfghjkmnpqrstvwxyz’;

$code = ”;

$i = 0;

while ($i < $characters) {

$code .= substr($possible, mt_rand(0, strlen($possible)-1), 1);

$i++;

}

return $code;

}


function CaptchaSecurityImages($width=’120′,$height=’40’,$characters=’6′) {

$code = $this->generateCode($characters);

/* font size will be 75% of the image height */

$font_size = $height * 0.75;

$image = @imagecreate($width, $height) or die(’Le librerie gd non sono installate nel tuo php’);

/* set the colours */

$background_color = imagecolorallocate($image, 255, 255, 255);

$text_color = imagecolorallocate($image, 20, 40, 100);

$noise_color = imagecolorallocate($image, 100, 120, 180);

/* generate random dots in background */

for( $i=0; $i<($width*$height)/3; $i++ ) {

imagefilledellipse($image, mt_rand(0,$width), mt_rand(0,$height), 1, 1, $noise_color);

}

/* generate random lines in background */

for( $i=0; $i<($width*$height)/150; $i++ ) {

imageline($image, mt_rand(0,$width), mt_rand(0,$height), mt_rand(0,$width), mt_rand(0,$height), $noise_color);

}

/* create textbox and add text */

$textbox = imagettfbbox($font_size, 0, $this->font, $code) or die(’Error in imagettfbbox function’);

$x = ($width – $textbox[4])/2;

$y = ($height – $textbox[5])/2;

imagettftext($image, $font_size, 0, $x, $y, $text_color, $this->font , $code) or die(’Error in imagettftext function’);

/* output captcha image to browser */

header(’Content-Type: image/jpeg’);

imagejpeg($image);

imagedestroy($image);

$_SESSION[’security_code’] = $code;

}


}


$width = isset($_GET[’width’]) ? $_GET[’width’] : ’120’;

$height = isset($_GET[’height’]) ? $_GET[’height’] : ’40’;

$characters = isset($_GET[’characters’]) && $_GET[’characters’] > 1 ? $_GET[’characters’] : ’6’;


$captcha = new CaptchaSecurityImages($width,$height,$characters); //Stampiamo la classe

?>[/php]

2 ) Scaricate e caricate sul vostro spazio web anche questo file

Esempio di utilizzo

Codice form html(Pagina form.php):

<form action=”form.php” method=”post”>

Nome: <input type=”text” name=”nome” />

<br><img src=”antispam.php?width=100&height=40&characters=5″ /><br />

<label for=”security_code”>Ricopia il codice che vedi nell’immagine </label><input id=”security_code” name=”security_code” type=”text” /><br />

<br><input type=”submit” name=”send” value=”Invia”/>

</form>

<?php

if ($_POST[’send’]){

session_start();

if ($_SESSION[’security_code’] == $_POST[’security_code’]){

echo ”Il codice antispam è giusto!”;

echo $_POST[’nome’];

//RISULTATO POSITIVO

} else {

echo ”Il codice antispam che hai inserito è errato!”;

}

}
[/php]

Ovviamente, quello sovrastante era solo un banale esempio.

Avrete capito che il codice di base da inserire tra i tag <form> e </form> è il seguente:

<img src=”antispam.php?width=100&height=40&characters=5″ /><br />

<label for=”security_code”>Ricopia il codice che vedi nell’immagine </label><input id=”security_code” name=”security_code” type=”text” />

e quello da inserire nel php e’ un controllo (if ) di uguaglianza ( == ) tra $_SESSION[’security_code’] e $_POST[’security_code’].


Similar Posts

Lämna ett svar