來源:互聯網
上載者:User
關鍵字
背景
驗證
帶有
產生
mt_rand
aimg
圖
驗證碼
PHP產生帶有雪花背景的驗證碼
//檢驗校正碼
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');
?>
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 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);
}
?>