当cookie关闭时,将字符串从php Captcha图像脚本传递到另一个php脚本

时间:2022-07-05 17:08:14

I have a php captcha image script that passes back the captcha code using a session variable, but this won't work if cookies are switched off.

我有一个php验证码图像脚本,它使用会话变量传回验证码,但如果关闭cookie,这将无效。

I want to try cover all eventualities, so my form will work even if cookies are switched off.

我想尝试涵盖所有可能性,因此即使关闭cookie,我的表单也能正常工作。

I was wondering if there was a way to pass $code back from captcha.php to contactus.php without using session variables.

我想知道是否有办法将$ code从captcha.php传递回contactus.php而不使用会话变量。

I doubt it, but I thought I'd ask to see if I was missing anything.

我对此表示怀疑,但我想我会问我是否遗漏了任何东西。

captcha.php

captcha.php

session_start();

class CaptchaSecurityImages {

    var $font = '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, 20, 40, 100);
    /* 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['six_letters_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);

Contactus.php

Contactus.php

<img id="captchaimg" alt="captchaimg" src="<?php echo htmlentities(getSiteURL() . '/server/includes/captcha.php'); ?>"

1 个解决方案

#1


1  

Your question is more about managing session without having a cookie support, read this article of how to handle session without using cookie

您的问题更多是关于在没有cookie支持的情况下管理会话,请阅读本文,了解如何在不使用cookie的情况下处理会话

#1


1  

Your question is more about managing session without having a cookie support, read this article of how to handle session without using cookie

您的问题更多是关于在没有cookie支持的情况下管理会话,请阅读本文,了解如何在不使用cookie的情况下处理会话