/function/Function.EditProfile.CaptchaSecurityImages.php
PHP | 62 lines | 43 code | 19 blank | 0 comment | 4 complexity | 38ef8c172eca484a133e66248c49712c MD5 | raw file
Possible License(s): GPL-2.0
- <?PHP
- session_name("CUST");
- session_start();
- class CaptchaSecurityImages {
- var $font = 'monofont.ttf';
- function generateCode($characters) {
-
- $possible = '45673ABCDEFGHIJKLMN';
- $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 = $height * 0.75;
- $image = @imagecreate($width, $height) or die('Cannot initialize new GD image stream');
-
- $background_color = imagecolorallocate($image, 225, 225, 195);
- $text_color = imagecolorallocate($image, 245, 2, 13);
- $noise_color = imagecolorallocate($image, 225, 200, 100);
-
- for( $i=0; $i<($width*$height)/3; $i++ ) {
- imagefilledellipse($image, mt_rand(0,$width), mt_rand(0,$height), 1, 1, $noise_color);
- }
-
- 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);
- }
-
- $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');
-
- header('Content-Type: image/jpeg');
- imagejpeg($image);
- imagedestroy($image);
-
- $_SESSION['editprofile_code'] = $code;
-
-
-
- }
- }
- $width = isset($_GET['width']) ? $_GET['width'] : '100';
- $height = isset($_GET['height']) ? $_GET['height'] : '30';
- $characters = isset($_GET['characters']) && $_GET['characters'] > 1 ? $_GET['characters'] : '6';
- $captcha = new CaptchaSecurityImages($width,$height,$characters);
- ?>