(不依赖于JavaScript开启)
编辑:
但我正在寻找 PHP数字Javascript独立验证码 我发现的唯一数字验证码是ASP.NET或基于jQuery / JS的 我不希望其中任何一个作为问题的答案。
我不会在这里找一个小网站。在答案中,我想知道你的建议是否给服务器带来了很大压力。
答案 0 :(得分:16)
我想在处理验证码时处理渲染图像是不可避免的? 这是一个简单的(可能不是最优雅的):
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的看法),一个独立的图像就是你所需要的。
最简单的是,数字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,我认为很难实现。但我认为这是一个很好的解决方案。
修改的
另一种解决方案是盲目验证码。它很容易实现并且工作得很好(长期以来有很好的经验)。它的工作原理如下:
简单但有效。
答案 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文件,并从生成验证码字的字符串中删除字母