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);

?>

私のフォームは次のようになります:
ここに画像の説明を入力

以前は魅力のように機能していましたが、フォームの送信時に突然、ユーザーが入力した CAPTCHA が画像と一致しないというエラーが頻繁に発生します。 $_SESSION['security_code'] 値はサーバー上で独自に変更され、もちろん写真は更新されませんでした.フォームをクリックして、送信前に任意のフィールドに入力を開始すると、キャプチャ写真のリンクを照会していたため、問題が発生しました (次のようになります:- ここに画像の説明を入力 、私の HTML ファイルは、このようなイベントの発生を引き起こす可能性のある JavaScript を使用していないことに注意してください。Kaspersky を使用せずに別のコンピューターからダブルチェックを試みたところ、動作しました。

問題は、カスペルスキーを使用し、私のフォームを使用したい潜在的なユーザーのために、これをどのように修正するかです。

4

0 に答える 0