- UID
- 62810
- 帖子
- 64
- 主題
- 33
- 精華
- 0
- 積分
- 34
- 楓幣
- 2964
- 威望
- 32
- 存款
- 0
- 贊助金額
- 0
- 推廣
- 0
- GP
- 32
- 閱讀權限
- 10
- 性別
- 保密
- 在線時間
- 41 小時
- 註冊時間
- 2014-5-26
- 最後登入
- 2019-5-7
|
一個非常簡單的PHP驗證碼生成例子,在這個PHP驗證碼生成我們需要使用到php_gd2.dll擴展了,下面我就來給大家整個例子了,希望對各位朋友會帶來幫助哦。
使用PHP的GD庫擴展類製作驗證碼的基本步驟:
啟用php.ini配置文件中的extension=php_gd2.dll擴展(打開php.ini配置文件,去掉行首的分號後重啟Apache即可);
下面是PHP生成驗證碼的代碼:- <?php
- for($i=0;$i<5;$i++){
- $suijishu.=dechex(rand(1,15));//使用循環產生一個十六進制格式的五位數
- }
- setcookie("useryzm",$suijishu);//創建一個名為useryzm、值為$suijishu的cookie
- $img=imagecreatetruecolor(100,30);//創建一個寬100高30的圖片驗證碼
- $bg=imagecolorallocate($img,rand(0,255),rand(0,255),rand(0,255));//定義驗證碼的背景顏色
- $sc=imagecolorallocate($img,rand(0,255),rand(0,255),rand(0,255));//定義驗證碼字體的顏色
- imagestring($img,5,rand(0,50),rand(0,15),$suijishu,$sc);//定義字體的位置(左上角為坐標原點)
- for($k=0;$k<10;$k++){
- imageline($img,rand(1,100),rand(1,100),rand(1,100),rand(1,100),$sc);//在驗證碼上繪製直線(擾亂作用)
- imagesetpixel($img,rand(1,100),rand(1,30),$sc);//在驗證碼上繪製點(擾亂作用)
- }
- ob_clean();//清空輸出緩衝區(這句很重要)
- header("Content-type:image/jpeg");//定義輸出圖片的格式(image/後面可以是jpeg或png或gif等圖片格式)
- imagejpeg($img);//輸出圖像
- imageDestroy($img);//釋放內存,完成創建
- ?>
複製代碼 下面是HTML中調用驗證碼的代碼:- <html>
- ...
- <script language="javascript">
- function changeyzm(){
- var img = document.getElementById("yzmimg").src = "gdyzm.php?id="+Math.random()*10;
- return ;
- }
- </script>
- ...
- <img src="gdyzm.php" name="yzmimg" width="100" height="30" id="yzmimg" title="點擊刷新" onclick="changeyzm();" />
- ...
- </html>
複製代碼 如果出現"圖像「XXXX」因其本身有錯無法顯示"的錯誤,很可能是漏了ob_clean();這句,或是文件的物理編碼出了問題(修改物理編碼的方法可以參考PHP創建utf8文件)
如果沒有加ob_clean();這句,在本地測試且物理編碼為ANSI時沒問題,物理編碼為UTF-8時則會報錯(圖像「XXXX」因其本身有錯無法顯示) |
|