1.php代码
<?php //随机生成一个4位数的数字验证码 $num=""; for($i=0;$i<4;$i++){ $num .= rand(0,9); } //4位验证码也可以用rand(1000,9999)直接生成 //将生成的验证码写入session,备验证页面使用 Session_start(); $_SESSION["Checknum"] = $num; //创建图片,定义颜色值 Header("Content-type: image/PNG"); srand((double)microtime()*1000000); $im = imagecreate(60,20); $black = ImageColorAllocate($im, 100,124,45); $gray = ImageColorAllocate($im, 250,250,250); imagefill($im,0,0,$gray); //随机绘制两条虚线,起干扰作用 $style = array($black, $black, $black, $black, $black, $gray, $gray, $gray, $gray, $gray); imagesetstyle($im, $style); $y1=rand(0,20); $y2=rand(0,20); $y3=rand(0,20); $y4=rand(0,20); imageline($im, 0, $y1, 60, $y3, IMG_COLOR_STYLED); imageline($im, 0, $y2, 60, $y4, IMG_COLOR_STYLED); //在画布上随机生成大量黑点,起干扰作用; for($i=0;$i<80;$i++) { imagesetpixel($im, rand(0,60), rand(0,20), $black); } //将四个数字随机显示在画布上,字符的水平间距和位置都按一定波动范围随机生成 $strx=rand(3,8); for($i=0;$i<4;$i++){ $strpos=rand(1,6); imagestring($im,5,$strx,$strpos, substr($num,$i,1), $black); $strx+=rand(8,12); } ImagePNG($im); ImageDestroy($im); ?>
2.前台
请输入验证码:
<input type=text name=passcode>
<img src=showimg.php>
3.验证处
$code=$_POST["passcode"];
if( $code == $_SESSION["Checknum"]){
验证通过
}else{
验证码错误
}
4.js切换验证码图片时,url后加一串随即数,防止因缓存的原因而没有改变。
var r = Math.random();
document.getElementById('checkcodepic').src="/drupal/sites/all/themes/mytheme/getcode.php?"+r;