首頁 >後端開發 >php教程 >用php產生帶有雪花背景的驗證碼

用php產生帶有雪花背景的驗證碼

WBOY
WBOY原創
2016-07-25 09:07:16785瀏覽
用php生成带有雪花背景的验证码,有需要的朋友可以参考下。以下代码,有详细的注释,方便学习。
<?session_start();?> 
<FORM METHOD=POST ACTION=""> 
<input type=text name=number maxlength=4><img  src="YanZhengMa.php?act=init" alt="用php產生帶有雪花背景的驗證碼" > 
<INPUT TYPE="submit" name="sub"> 
</FORM> 
<? 
//检验校验码 
if(isset($HTTP_POST_VARS["sub"])): 
if($HTTP_POST_VARS["number"] != $HTTP_SESSION_VARS[login_check_number] || empty($HTTP_POST_VARS["number"])){ 
    echo "校验码不正确!" ; 
}else{ 
    echo"验证码通过!"; 
} 
endif; 
show_source('test.php'); 
//以上本页的源码


//以下是生成验证码的源码 
show_source('YanZhengMa.php'); 
?> 
<?php 
session_start(); 
session_register("login_check_number"); 
//昨晚看到了chianren上的验证码效果,就考虑了一下,用PHP的GD库完成了类似功能 
//先成生背景,再把生成的验证码放上去 
$img_height=120;    //先定义图片的长、宽 
$img_width=40; 
if($HTTP_GET_VARS["act"]== "init"){ 
    //srand(microtime() * 100000);//PHP420后,srand不是必须的 
    for($Tmpa=0;$Tmpa<4;$Tmpa++){ 
        $nmsg.=dechex(rand(0,15)); 
    }//by sports98


    $HTTP_SESSION_VARS[login_check_number] = $nmsg;

    //$HTTP_SESSION_VARS[login_check_number] = strval(mt_rand("1111","9999"));    //生成4位的随机数,放入session中 
    //谁能做下补充,可以同时生成字母和数字啊??----由sports98完成了

    $aimg = imageCreate($img_height,$img_width);    //生成图片 
    ImageColorAllocate($aimg, 255,255,255);            //图片底色,ImageColorAllocate第1次定义颜色PHP就认为是底色了 
    $black = ImageColorAllocate($aimg, 0,0,0);        //定义需要的黑色 
    ImageRectangle($aimg,0,0,$img_height-1,$img_width-1,$black);//先成一黑色的矩形把图片包围

    //下面该生成雪花背景了,其实就是在图片上生成一些符号 
    for ($i=1; $i<=100; $i++) {    //先用100个做测试 
        imageString($aimg,1,mt_rand(1,$img_height),mt_rand(1,$img_width),"*",imageColorAllocate($aimg,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255))); 
        //哈,看到了吧,其实也不是雪花,就是生成*号而已。为了使它们看起来"杂乱无章、5颜6色",就得在1个1个生成它们的时候,让它们的位置、颜色,甚至大小都用随机数,rand()或mt_rand都可以完成。 
    }

    //上面生成了背景,现在就该把已经生成的随机数放上来了。道理和上面差不多,随机数1个1个地放,同时让他们的位置、大小、颜色都用成随机数~~ 
    //为了区别于背景,这里的颜色不超过200,上面的不小于200 
    for ($i=0;$i<strlen($HTTP_SESSION_VARS[login_check_number]);$i++){ 
        imageString($aimg, mt_rand(3,5),$i*$img_height/4+mt_rand(1,10),mt_rand(1,$img_width/2), $HTTP_SESSION_VARS[login_check_number][$i],imageColorAllocate($aimg,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200))); 
    } 
    Header("Content-type: image/png");    //告诉浏览器,下面的数据是图片,而不要按文字显示 
    ImagePng($aimg);                    //生成png格式。 
    ImageDestroy($aimg); 
}
?>


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn