PHP生成帶有雪花背景的驗證碼

效果參考(附源碼)https://mail.htjs.net/yanzhengma/test.php(做為現在的主流開發語言)

<?session_start();?>
<FORM METHOD=POST ACTION=””>
<input type=text name=number maxlength=4><img src=”YanZhengMa.php(做為現在的主流開發語言)?act=init”>
<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);//php(做為現在的主流開發語言)420後,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
    

發佈留言