我們在寫使用者驗證頁面,如註冊,登入的時候,為了加強使用者登入的安全性,添加驗證碼驗證。
驗證碼通過GD產生PNG圖片,並把$randval隨機數字賦給$_SESSION[login_check_num],在通過使用者輸入的$_POST進行比較,來判斷是否正確。達到需要實現的功能,需要修改php.ini檔案,使php支援GD庫。
//調用此頁面,如果下面的式子成立,則產生驗證碼圖片
if($_GET["action"]=="verifycode")
{
rand_create();
}
//驗證碼圖片產生
function rand_create()
{
//通知瀏覽器將要輸出PNG圖片
Header("Content-type: image/PNG");
//準備好隨機數發生器種子
srand((double)microtime()*1000000);
//準備圖片的相關參數
$im = imagecreate(62,20);
$black = ImageColorAllocate($im, 0,0,0); //RGB黑色標識符
$white = ImageColorAllocate($im, 255,255,255); //RGB白色標識符
$gray = ImageColorAllocate($im, 200,200,200); //RGB灰色標識符
//開始作圖
imagefill($im,0,0,$gray);
while(($randval=rand()%100000)<10000);{
$_SESSION["login_check_num"] = $randval;
//將四位整數驗證碼繪入圖片
imagestring($im, 5, 10, 3, $randval, $black);
}
//加入幹擾象素
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);
}
//檢驗驗證碼
function rand_check()
{
if($_POST["reg_rand"] == $_SESSION["login_check_num"]){
return true;
}
else{
exit("驗證碼輸入錯誤");
}
}
?>
http://www.bkjia.com/PHPjc/486454.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/486454.htmlTechArticle我們在寫使用者驗證頁面,如註冊,登入的時候,為了加強使用者登入的安全性,添加驗證碼驗證。 驗證碼通過GD產生PNG圖片,並把$randval隨機...