CAPTCHA ("Completely Automated Public Turing test to tell Computers and Humans Apart") mostly used to block/ protecting you against common spam bots
that try to automatically spamming your mails box or trying to automatically sign up in web sites, blogs and forums.
Below show how to create CAPTCHA in PHP for your web sites.
Let Get Started!!
1st Step: Create Captcha Image with Random String
Let Get Started!!
1st Step: Create Captcha Image with Random String
button.png |
- Create an image with some background noise and name it as button.png show on above. This button.png is use to avoid the randon string readable.
- To test Captcha image is readable or not go to http://www.onlineocr.net/
- Create an image.php file, copy and paste below codes. This file is set as an image/png Content-Type to avoid user able to highlighted the random string as a text.
<?php // Create random 5 characters string, taking out 'o' and 'q', 'I', 'T' to avoid confusion with '0', '2' and 'I' 'T' look familiar $random_string = str_shuffle('abcdefghjkmnprsuvwxyz'); $characters = strtoupper(substr($random_string, 0, 5)); // Concatenate the random string onto the random numbers // '0' is left out to avoid confusion with 'O' $string = rand(1, 9). $characters . rand(1, 9); // Start session to store $str in Session session_start(); $_SESSION['captcha_id'] = $string; // Set this php file into image content type header('Content-Type: image/png'); header('Cache-Control: no-cache'); // Set the font type
$font = '../fonts/Lucida Calligraphy Italic.ttf'; // Create an image from button.png (http://php.net/manual/en/function.imagecreatefrompng.php). This button.png is an image with some background noise. $image = imagecreatefrompng('button.png'); // Set the font colour (http://php.net/manual/en/function.imagecolorallocate.php) $colour = imagecolorallocate($image, 183, 178, 152); // Set the rotation between -10 and 10 degrees $rotate = rand(-10, 10); // Create an image with the random string, rotation, color, font and image (http://php.net/manual/en/function.imagettftext.php) imagettftext($image, 14, $rotate, 18, 30, $colour, $font, $string); // Output the image as a png (http://php.net/manual/en/function.imagepng.php) imagepng($image); ?>
- For changing the font type go to http://www.1001freefonts.com/ and make changes on below part of code in image.php
- Below show the result of image.php file.
Captcha image |
- Create an captcha.html file, copy and paste below codes.
CAPTCHA
- Below show the result of captcha.html file
Result of captcha.html |
- After click Submit button will compare $_POST['text_captcha'] string is match with captcha string in Uppercase.
- Create validate.php file, copy and paste below codes.
<?php // Start session session_start(); if(strtoupper($_POST['text_captcha']) == $_SESSION['captcha_id']) echo 'true'; else echo 'false'; ?>
- If match will return "true" else "false".
- Please do not hesitate to comment if you have any problems.
Video of PHP, CAPTCHA & AJAX Contact Form
Easy to implement, No other library used, Just implement some JQuery for AJAX posting and PHP for generated random characters, font rendering and validated input. Good job.
ReplyDeleteSuggestion: reload validate code function combine with click event of generated image is better. It might enhance user experiences.
Thanks Ronnie about your suggestions.
Deletevery easy, thanks
ReplyDeleteThank you for tutorial, Keny.
ReplyDeleteBest Regards,
http://www.totomshop.com