數字驗證碼
<?
/*
* Filename: authpage.php
*/
session_start();
// srand((double)microtime()*1000000);
$authnum = $_SESSION[''authnum''];
//驗證使用者輸入是否和驗證碼一致
if(isset($_POST[''authinput'']))
{
if(strcmp($_POST[''authinput''],$_SESSION[''authnum''])==0)
echo "驗證成功!";
else
echo "驗證失敗!";
}
//產生新的四位整數驗證碼
// while(($authnum=rand()%10000)<1000);
?>
<form action=test4.php method=post>
<table>
請輸入驗證碼:<input type=text name=authinput style="width: 80px"><br>
<input type=submit name="驗證" value="提交驗證碼">
<input type=hidden name=authnum value=<? echo $authnum; ?>>
<img src=authimg.php?authnum=<? echo $authnum; ?>>
</table>
</form>
authimg.php
<?php
//產生驗證碼圖片
Header("Content-type: image/PNG");
srand((double)microtime()*1000000);//播下一個產生隨機數位種子,以方便下面隨機數產生的使用
session_start();//將隨機數存入session中
$_SESSION[''authnum'']="";
$im = imagecreate(62,20); //制定圖片背景大小
$black = ImageColorAllocate($im, 0,0,0); //設定三種顏色
$white = ImageColorAllocate($im, 255,255,255);
$gray = ImageColorAllocate($im, 200,200,200);
imagefill($im,0,0,$gray); //採用地區填充法,設定(0,0)
while(($authnum=rand()%100000)<10000);
//將四位整數驗證碼繪入圖片
$_SESSION[''authnum'']=$authnum;
imagestring($im, 5, 10, 3, $authnum, $black);
// 用 col 顏色將字串 s 畫到 image 所代表的映像的 x,y 座標處像的左上方為 0, 0)。
//如果 font 是 1,2,3,4 或 5,則使用內建字型
for($i=0;$i<200;$i++) //加入幹擾象素
{
$randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
imagesetpixel($im, rand()%70 , rand()%30 , $randcolor);
}
ImagePNG($im);
ImageDestroy($im);
?>
<