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的情况下处理会话