php新手,寫了一個web登錄界面,除了用戶名,密碼,感覺有個驗證碼會比較cool一點,便根據參考書的簡單介紹,寫了一個image.php來生成簡單的圖片驗證碼,頗有感慨,分享一下。
1. 圖片驗證碼生成步驟:
(1)產生隨機字符串(假設只需6位),使用session進行保存,以便驗證;
<?php $string = "abcdefghijklmnopqrstuvwxyz0123456789";
$str = ""; for($i=0;$i<6;$i++){ $pos = rand(0,35); $str .= $string{$pos}; } session_start(); $_SESSION['img_number'] = $str;
(2)創建一張簡單的圖片(80X20),設置背景色,文本色,再加一些干擾線,干擾素;
$img_handle = Imagecreate(80, 20); //圖片大小80X20 $back_color = ImageColorAllocate($img_handle, 255, 255, 255); //背景顏色(白色) $txt_color = ImageColorAllocate($img_handle, 0,0, 0); //文本顏色(黑色) //加入干擾線 for($i=0;$i<3;$i++) { $line = ImageColorAllocate($img_handle,rand(0,255),rand(0,255),rand(0,255)); Imageline($img_handle, rand(0,15), rand(0,15), rand(100,150),rand(10,50), $line); } //加入干擾象素 for($i=0;$i<200;$i++) { $randcolor = ImageColorallocate($img_handle,rand(0,255),rand(0,255),rand(0,255)); Imagesetpixel($img_handle, rand()%100 , rand()%50 , $randcolor); }
(3)填充圖片背景色,再將產生的隨機字符串填充圖片;
Imagefill($img_handle, 0, 0, $back_color); //填充圖片背景色 ImageString($img_handle, 28, 10, 0, $str, $txt_color);//水平填充一行字符串
(4)清空輸出緩存區,再生成驗證碼圖片,並顯示圖片。
ob_clean(); // ob_clean()清空輸出緩存區 header("Content-type: image/png"); //生成驗證碼圖片 Imagepng($img_handle);//顯示圖片 ?>
2. 圖片驗證碼的引用
在form表單中添加驗證碼圖片,src=“image.php” 就是根據上面步驟用於產生驗證碼圖片的php,為了增加效果,添加了js刷新驗證碼的功能,可以參考。
<form id="form1" name="form1" method="post" action="post.php"> <input type="text" name="code" /> <img src="image.php" id = "refresh" title="刷新驗證碼" align="absmiddle" onclick="document.getElementById('refresh').src='image.php' "> <font color="#ffffff">點擊圖片刷新</font> <input type="submit" value="登錄"/> </form>
3. 驗證碼的驗證
在post.php中使用第一步保存字符串的session與用戶輸入的驗證碼進行匹配。
<?php session_start(); if($_POST['code'] == $_SESSION['img_number']){ echo "驗證碼正確"; }else{ echo "驗證碼錯誤"; } ?>
4. 效果展示:
生成的驗證碼圖片:
在登錄框中的效果:
4. 遺留問題探討
(1)生成驗證碼圖片,並顯示圖片前,為何要使用ob_clean()清空輸出緩存區 ??
鑒於本人對於PHP不太熟悉,可參考 :http://www.php.net/manual/zh/function.ob-clean.php
(2)填充進圖片的字體有沒有辦法設置大小??
ImageString這個函數使用的是內置字體,只能換成imagettftext()函數。可參考:http://us3.php.net/manual/zh/function.imagettftext.php
歡迎討論,請輕噴~