PHP的数字Captcha

时间:2011-05-18 08:00:19

标签: php numbers captcha

PHP 是否有数字验证码?

不依赖于JavaScript开启


编辑:

  • 我知道有JS独立 验证码。
  • 我知道那里 是PHP验证码。
  • 我知道 那里有数字验证码。

但我正在寻找 PHP数字Javascript独立验证码 我发现的唯一数字验证码是ASP.NET或基于jQuery / JS的 我不希望其中任何一个作为问题的答案。

我不会在这里找一个小网站。在答案中,我想知道你的建议是否给服务器带来了很大压力。

6 个答案:

答案 0 :(得分:16)

我想在处理验证码时处理渲染图像是不可避免的? 这是一个简单的(可能不是最优雅的):

sample output

session_start();

$strings = '123456789';
$i = 0;
$characters = 6;
$code = '';
while ($i < $characters)
{ 
    $code .= substr($strings, mt_rand(0, strlen($strings)-1), 1);
    $i++;
} 

$_SESSION['captcha'] = $code;

//generate image
$im = imagecreatetruecolor(124, 40);
$foreground = imagecolorallocate($im, 0, 0, 0);
$shadow = imagecolorallocate($im, 173, 172, 168);
$background = imagecolorallocate($im, 255, 255, 255);

imagefilledrectangle($im, 0, 0, 200, 200, $background);

// use your own font!
$font = 'monofont.ttf';

//draw text:
imagettftext($im, 35, 0, 9, 28, $shadow, $font, $code);
imagettftext($im, 35, 0, 2, 32, $foreground, $font, $code);     

// prevent client side  caching
header("Expires: Wed, 1 Jan 1997 00:00:00 GMT");
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
header("Cache-Control: no-store, no-cache, must-revalidate");
header("Cache-Control: post-check=0, pre-check=0", false);
header("Pragma: no-cache");

//send image to browser
header ("Content-type: image/png");
imagepng($im);
imagedestroy($im);

以表格形式显示:

<img src="captcha.php">
Enter the code above: <input type="text" name="captcha">

提交后,请检查输入的代码:

if ($_POST['captcha'] == $_SESSION['captcha'])
    // do your thing

答案 1 :(得分:3)

CAPTCHA不一定依赖于javascript(我认为你对reCATCHA的看法),一个独立的图像就是你所需要的。

http://www.phpcaptcha.org/

最简单的是,数字CAPTCHA的工作方式就像......

<?php
session_start();

if (isset($_POST['code'])) {
    if ($_POST['code'] == $_SESSION['captcha']) {
        echo "Captcha valid";
    }
    else {
        echo "Captcha NOT valid";
    }
}

$_SESSION['captcha'] = mt_rand(10000, 99999);
?>
<form action="" method="post">
    <p>Enter this number: <?php echo $_SESSION['captcha']; ?></p>
    <p><input type="text" name="code" /> <input type="submit" value="Submit" />
</form>

答案 2 :(得分:1)

您可能也想过figlet验证码。这节省了大量时间,因为您不需要渲染图像。在我的主页上,我正在使用这种验证码。您可以查看this page(滚动到底部,您无法监督它;))。我已经通过Zend-Framework实现了它。最好用Zend_Captcha_Figlet说。

但是,如果您不使用Zend_Form,我认为很难实现。但我认为这是一个很好的解决方案。

修改

另一种解决方案是盲目验证码。它很容易实现并且工作得很好(长期以来有很好的经验)。它的工作原理如下:

  • 在表单中提供一个空值的输入字段。
  • 最初通过css隐藏它(这不应该使用内联样式)
  • 在表单验证(php)中检查此字段是否包含值。如果是这样,它可能是一个填充每个输入字段的spambot。
  • 用户不会填写它,因为他没有看到它(当然他会看到它,如果他在浏览器中禁用了css)

简单但有效。

答案 3 :(得分:1)

You can use http://www.captcha.ru/kcaptcha/包含jQuery Accordion列表项默认此库生成带字母符号的键,但您可以更改配置文件(为变量设置新值$ allowed_symbols =&# 34; 0123456789&#34;例如)仅用于生成数字键。

答案 4 :(得分:0)

不要使用任何其他php文件在表单中添加数字验证码。只需尝试以下

    <input id="num1" type="text" name="num1" value="<?php echo rand(1,4); ?>" readonly="readonly" /> +
<input id="num2" type="text" name="num2" value="<?php echo rand(5,9); ?>" readonly="readonly" /> =
<input id="captcha" class="captcha" type="text" onblur="check_captcha(this.value);" maxlength="2" />  

并且在功能中您可以轻松验证

<script>
function check_captcha(res)
{
if(res)
{
var val=parseInt($('#num1').val())+parseInt($('#num2').val());
if(val!=res)
{
alert('Incorrect value, please try again');
$('#captcha').val('');
$('#captcha').focus();
}
}
}
</script>

答案 5 :(得分:0)

只需打开任何验证码php文件,并从生成验证码字的字符串中删除字母