0

我正在开发一个使用 PHP 验证码脚本的 HTML 用户表单:

<?php
session_start();


class CaptchaSecurityImages {

    var $font = 'php/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('Cannot initialize new GD image stream');
        /* 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);

?>

我的表格看起来像:
在此处输入图像描述

它曾经像魅力一样工作,并且突然提交表单我经常收到用户输入的验证码与图片不匹配的错误,进一步调查我发现:在 chrome 中,一旦我单击表单中的任何字段而不键入$_SESSION['security_code'] 值在服务器上自行更改,当然照片从未更新,进一步调查我发现我的卡巴斯基在 chrome 中设置了一些事件监听器,这似乎是导致问题,因为一旦我单击表单并在提交前开始在任何字段中输入,他们就会查询验证码照片链接(它们看起来像这样:- 在此处输入图像描述 ,请注意,我的 HTML 文件没有使用任何可能导致此类事件触发的 javascript,作为我在没有卡巴斯基的另一台计算机上尝试过的双重检查,它可以正常工作。

现在的问题是如何为使用卡巴斯基并希望使用我的表单的潜在用户解决此问题?

4

0 回答 0