PHP Classes
elePHPant
Icontem

CAPTCHA 2: Generate CAPTCHA validation images

Recommend this page to a friend!
  Info   Screenshots Screenshots   View files View files (4)   DownloadInstall with Composer Download .zip   Reputation   Support forum (4)   Blog    
Last Updated Ratings Unique User Downloads Download Rankings
2007-03-13 (9 years ago) RSS 2.0 feedStarStarStarStar 70%Total: 4,887 All time: 532 This week: 1,068Down
Version License PHP version Categories
captcha2 0.9GNU General Publi...5.0PHP 5, Graphics, Validation
Description Author

This class can be used to generate images for CAPTCHA validation.
Now it's a brand new class. More complicated captchas, cleaner code.

Peace.

Picture of Cristian Navalici
Name: Cristian Navalici <contact>
Classes: 4 packages by
Country: Romania Romania

Details
README for the CAPTCHA 2 class
by Cristian Navalici
=============================================================================

1.0 How to use the class?
2.0 Requirements
3.0 What is a CAPTCHA?
3.1 What are the applications for CAPTCHAs?

4.0 Author
4.1 License

=============================================================================
1.0 How to use the class?
=============================================================================
It's realy easy to use this class.

You need to know about 3 functions to operate it properly:

function createCaptcha($length = 6, $type = 'png', $draw_lines = 'true')
function showCaptcha() 
function verifyCaptcha($txt)

//----------------------
function createCaptcha - generate the captcha based on your arguments
$length 	- how long do you want the string showed in picture? (default: 6)
$type 		- what type do you want to be saved picture? (possible: png/jpeg, default: png)
$draw_lines 	- do you want to add some lines to the picture to make it even more difficult to read? (default: true)
All parameters have defaults so you doesn't need to enter any of the parameters.
//----------------------

//----------------------
function showCaptcha() - show on a html page generated captcha (must follow createCaptcha function)
Generated string is a random one (made by combination of letters (A-Z) and digits (2-9) 
(0 is excluded; it can be confounded on some fonts with letter 'O'; idem for digit 1 and letter l).
//----------------------

//----------------------
function verifyCaptcha($txt) - verify if generated captcha is the same with user input ($txt)
//----------------------
See example.php for a detailed example.


There are some more modifications you can make into class itself.
These can be found in the first statements of the class:

// here you can make some adjustments
private $font_size 	= 18; 		// if GD2 in points / GD1 in pixels
private $font 		= 'bahamasn.ttf';
private $img_height 	= 40;
private $save_path 	= 'gdtest'; 	// without trailing slash
private $secret_key	= 'Insert a complicated string here';
private $secret_key	= 'Insert a complicated string here';

private $use_windows = 0; // 1 - if you'll use windows   0 - if don't
// until here

You can modify image height, font used in generated images or size of it.
In our example, images are saved in 'gdtest' folder. You can save wherever you want
but pay attention to directory write rights (apache must be able to write in it). 

You can modify in stringGenerator line
	$alphanumerics   = array_merge(range('A', 'Z'), range(2, 9));
to 
	$alphanumerics   = array_merge(range('A', 'Z'), range ('a', 'z'), range(0, 9));
if you want full range of letters and digits. Beware of some fonts that have minor differences between majuscules and minuscules.

Specify on $use_windows what SO you'll use.

=============================================================================
2.0 Requirements
=============================================================================
Apache + PHP5
PHP must be configured with GD options.
e.g. --with-gd --with-freetype-dir --enable-gd-native-ttf --with-ttf --enable-exif --with-jpeg-dir=/usr/lib/libjpeg.so 

Also must suport mcrypt.
--with-mcrypt
libmcrypt > 2.4.x
More details on: http://www.php.net/manual/en/ref.mcrypt.php


=============================================================================
3.0 What is a CAPTCHA?
=============================================================================
A CAPTCHA (an initialism for "Completely Automated Public Turing test to tell Computers and Humans Apart", trademarked by Carnegie Mellon University) is a type of challenge-response test used in computing to determine whether or not the user is human.
The term was coined in 2000 by Luis von Ahn, Manuel Blum, Nicholas J. Hopper of Carnegie Mellon University, and John Langford of IBM. A common type of CAPTCHA requires that the user type the letters of a distorted image, sometimes with the addition of an obscured sequence of letters or digits that appears on the screen. 

For more informations about CAPTCHAs please visit http://www.captcha.net/ or http://en.wikipedia.org/wiki/Captcha

=============================================================================
3.1 What are the applications for CAPTCHAs?
=============================================================================
CAPTCHAs have several applications for practical security,
including (but not limited to):

Online Polls.
  Can the result of any online poll be trusted? Not unless the poll requires
  that only humans can vote.

Free Email Services.
  Several companies (Yahoo!, Microsoft, etc.) offer free email services.
  Most of these suffer from a specific type of attack: "bots" that sign
  up for thousands of email accounts every minute.

Search Engine Bots.
  Search engine bots, since they usually belong to large companies, respect
  web pages that don't want to allow them in. However, in order to truly
  guarantee that bots won't enter a web site, CAPTCHAs are needed.

Worms and Spam.
  CAPTCHAs also offer a plausible solution against email worms and spam:
  "I will only accept an email if I know there is a human behind the other computer."

Preventing Dictionary Attacks.
  Pinkas and Sander have suggested using CAPTCHAs to prevent dictionary attacks in
  password systems. The idea is simple: prevent a computer from being able to
  iterate through the entire space of passwords.


=============================================================================
4.0 Author
=============================================================================
Cristian Navalici
cristian.navalici [at] gmail.com
http://goodies.graficoncept.ro

http://www.phpclasses.org/trackback/browse/package/3336.html


=============================================================================
4.1 License
=============================================================================
GNU General Public License (Version 2, June 1991)

This program is free software; you can redistribute
it and/or modify it under the terms of the GNU
General Public License as published by the Free
Software Foundation; either version 2 of the License,
or (at your option) any later version.

This program is distributed in the hope that it will
be useful, but WITHOUT ANY WARRANTY; without even the
implied warranty of MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE. See the GNU General Public License
for more details.
Screenshots  
  • Snapshot3
  • Snapshot2
  • Snapshot
  • Screenshot
  Files folder image Files  
File Role Description
Accessible without login Plain text file captcha.class.php Class Base Class
Accessible without login Plain text file example.php Example Testsuit
Accessible without login Plain text file Readme Doc. small FAQ and description of the class
Plain text file Fontused Data Where can I take it from?

 Version Control Unique User Downloads Download Rankings  
 0%
Total:4,887
This week:0
All time:532
This week:1,068Down
User Ratings User Comments (2)
 All time
Utility:90%StarStarStarStarStar
Consistency:84%StarStarStarStarStar
Documentation:75%StarStarStarStar
Examples:87%StarStarStarStarStar
Tests:-
Videos:-
Overall:70%StarStarStarStar
Rank:293
 
I used this class to help me with some animated captcha work ...
8 years ago (Dennis Lovelady)
80%StarStarStarStarStar
needs mcrypt!!!
9 years ago (Jörg Spieler)
32%StarStar