php中怎么實(shí)現(xiàn)一個(gè)驗(yàn)證碼功能

php中怎么實(shí)現(xiàn)一個(gè)驗(yàn)證碼功能,相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

站在用戶的角度思考問題,與客戶深入溝通,找到蠡縣網(wǎng)站設(shè)計(jì)與蠡縣網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、空間域名、網(wǎng)絡(luò)空間、企業(yè)郵箱。業(yè)務(wù)覆蓋蠡縣地區(qū)。

新建一個(gè)captcha.php:

php     //10>設(shè)置session,必須處于腳本最頂部     session_start();      $image = imagecreatetruecolor(100, 30);        //1>設(shè)置驗(yàn)證碼圖片大小的函數(shù)     //5>設(shè)置驗(yàn)證碼顏色 imagecolorallocate(int im, int red, int green, int blue);     $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff     //6>區(qū)域填充 int imagefill(int im, int x, int y, int col)  (x,y) 所在的區(qū)域著色,col 表示欲涂上的顏色     imagefill($image, 0, 0, $bgcolor);     //10>設(shè)置變量     $captcha_code = "";     //7>生成隨機(jī)數(shù)字     for($i=0;$i<4;$i++){         //設(shè)置字體大小         $fontsize = 6;                 //設(shè)置字體顏色,隨機(jī)顏色         $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));            //0-120深顏色         //設(shè)置數(shù)字         $fontcontent = rand(0,9);         //10>.=連續(xù)定義變量         $captcha_code .= $fontcontent;             //設(shè)置坐標(biāo)         $x = ($i*100/4)+rand(5,10);         $y = rand(5,10);          imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);     }     //10>存到session     $_SESSION['authcode'] = $captcha_code;     //8>增加干擾元素,設(shè)置雪花點(diǎn)     for($i=0;$i<200;$i++){         //設(shè)置點(diǎn)的顏色,50-200顏色比數(shù)字淺,不干擾閱讀         $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));                 //imagesetpixel &mdash; 畫一個(gè)單一像素         imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);     }     //9>增加干擾元素,設(shè)置橫線     for($i=0;$i<4;$i++){         //設(shè)置線的顏色         $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));         //設(shè)置線,兩點(diǎn)一線         imageline($image,rand(1,99), rand(1,29),rand(1,99), rand(1,29),$linecolor);     }      //2>設(shè)置頭部,image/png     header('Content-Type: image/png');     //3>imagepng() 建立png圖形函數(shù)     imagepng($image);     //4>imagedestroy() 結(jié)束圖形函數(shù)  銷毀$image     imagedestroy($image);

接著就是靜態(tài)頁(yè)的代碼了:index.html

  1. doctype html> 

  2. <html> 

  3.     <head> 

  4.         <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 

  5.         <title>確認(rèn)驗(yàn)證碼title> 

  6.     head> 

  7.     <body> 

  8.         <form method="post" action="./form.php"> 

  9.             <p>驗(yàn)證碼: <img id="captcha_img" border='1' src='./captcha.php?r=echo rand(); ?>' style="width:100px; height:30px" /> 

  10.                 <a href="javascript:void(0)" onclick="document.getElementById('captcha_img').src='./captcha.php?r='+Math.random()">換一個(gè)?a> 

  11.             p> 

  12.             <P>請(qǐng)輸入驗(yàn)證碼:<input type="text" name='authcode' value=''/>p> 

  13.             <p><input type='submit' value='提交' style='padding:6px 5px;'/>p>     

  14.     body> 

  15. html>

從index.html可以看到,提交的表單是到form.php的,所以還要有一個(gè)判斷的form.php代碼:

  1. php 

  2.     header("Content-Type:text/html;charset=utf-8");            //設(shè)置頭部信息 

  3.     //isset()檢測(cè)變量是否設(shè)置 

  4.     if(isset($_REQUEST['authcode'])){ 

  5.         session_start(); 

  6.         //strtolower()小寫函數(shù) 

  7.         if(strtolower($_REQUEST['authcode'])== $_SESSION['authcode']){ 

  8.             //跳轉(zhuǎn)頁(yè)面 

  9.             echo "<script language=\"javascript\">"; 

  10.             echo "document.location=\"./form.php\""; 

  11.             echo "</script>"; 

  12.         }else{ 

  13.             //提示以及跳轉(zhuǎn)頁(yè)面 

  14.             echo "<script language=\"javascript\">"; 

  15.             echo "alert('輸入錯(cuò)誤!');"; 

  16.             echo "document.location=\"./form.php\""; 

  17.             echo "</script>"; 

  18.         } 

  19.         exit(); 

  20.     }

顯示頁(yè)面如下:

php中怎么實(shí)現(xiàn)一個(gè)驗(yàn)證碼功能

那么,純數(shù)字的實(shí)現(xiàn)了,數(shù)字加英文的也應(yīng)該不難了。要修改的代碼   只是在 captcha.php 將 //7>生成隨機(jī)數(shù)字 修改成  //7>生成隨機(jī)的字母和數(shù)字,如果你真的很可愛的就修改這幾個(gè)字就認(rèn)為可以實(shí)現(xiàn)的話,那么祝賀你,你永遠(yuǎn)保持快樂。腦殘兒童歡樂多。

廢話不多說了,拉代碼吧?!?/p>

php     //10>設(shè)置session,必須處于腳本最頂部     session_start();      $image = imagecreatetruecolor(100, 30);        //1>設(shè)置驗(yàn)證碼圖片大小的函數(shù)     //5>設(shè)置驗(yàn)證碼顏色 imagecolorallocate(int im, int red, int green, int blue);     $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff     //6>區(qū)域填充 int imagefill(int im, int x, int y, int col)  (x,y) 所在的區(qū)域著色,col 表示欲涂上的顏色     imagefill($image, 0, 0, $bgcolor);     //10>設(shè)置變量     $captcha_code = "";     //7>生成隨機(jī)的字母和數(shù)字     for($i=0;$i<4;$i++){         //設(shè)置字體大小         $fontsize = 8;                 //設(shè)置字體顏色,隨機(jī)顏色         $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));            //0-120深顏色         //設(shè)置需要隨機(jī)取的值,去掉容易出錯(cuò)的值如0和o         $data ='abcdefghigkmnpqrstuvwxy3456789';         //取出值,字符串截取方法   strlen獲取字符串長(zhǎng)度         $fontcontent = substr($data, rand(0,strlen($data)),1);         //10>.=連續(xù)定義變量         $captcha_code .= $fontcontent;                 //設(shè)置坐標(biāo)         $x = ($i*100/4)+rand(5,10);         $y = rand(5,10);          imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);     }     //10>存到session     $_SESSION['authcode'] = $captcha_code;     //8>增加干擾元素,設(shè)置雪花點(diǎn)     for($i=0;$i<200;$i++){         //設(shè)置點(diǎn)的顏色,50-200顏色比數(shù)字淺,不干擾閱讀         $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));                 //imagesetpixel &mdash; 畫一個(gè)單一像素         imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);     }     //9>增加干擾元素,設(shè)置橫線     for($i=0;$i<4;$i++){         //設(shè)置線的顏色         $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));         //設(shè)置線,兩點(diǎn)一線         imageline($image,rand(1,99), rand(1,29),rand(1,99), rand(1,29),$linecolor);     }      //2>設(shè)置頭部,image/png     header('Content-Type: image/png');     //3>imagepng() 建立png圖形函數(shù)     imagepng($image);     //4>imagedestroy() 結(jié)束圖形函數(shù)  銷毀$image     imagedestroy($image);

其他的兩個(gè)頁(yè)面,不許要修改。

php中怎么實(shí)現(xiàn)一個(gè)驗(yàn)證碼功能

一般而言,現(xiàn)在就已經(jīng)夠用了。但是就像動(dòng)漫一樣,總會(huì)有番外。

那么,我們來個(gè)漢字的番外吧。其實(shí)我也準(zhǔn)備將漢字的驗(yàn)證碼放到我的畢業(yè)設(shè)計(jì)里面,雖然現(xiàn)在很流行滑動(dòng)驗(yàn)證碼,但是本人畢竟不是專門學(xué)習(xí)js的。

而且,還可以和答辯的老師說,我們驗(yàn)證碼不需要素材,連圖片也是生成的,用自己的知識(shí)裝13,也沒有設(shè)么的。 

php     //11>設(shè)置session,必須處于腳本最頂部     session_start();      //1>設(shè)置驗(yàn)證碼圖片大小的函數(shù)     $image = imagecreatetruecolor(200, 60);             //5>設(shè)置驗(yàn)證碼顏色 imagecolorallocate(int im, int red, int green, int blue);     $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff     //6>區(qū)域填充 int imagefill(int im, int x, int y, int col)  (x,y) 所在的區(qū)域著色,col 表示欲涂上的顏色     imagefill($image, 0, 0, $bgcolor);     //7>設(shè)置ttf字體     $fontface = 'FZYTK.TTF';     //7>設(shè)置字庫(kù),實(shí)現(xiàn)簡(jiǎn)單的數(shù)字儲(chǔ)備     $str='天地不仁以萬(wàn)物為芻狗圣人不仁以百姓為芻狗這句經(jīng)常出現(xiàn)在控訴暴君暴政上地殘暴不仁把萬(wàn)物都當(dāng)成低賤的豬狗來看待而那些高高在上的所謂圣人們也沒兩樣還不是把我們老百姓也當(dāng)成豬狗不如的東西但實(shí)在正取的解讀是地不情感用事對(duì)萬(wàn)物一視同仁圣人不情感用事對(duì)百姓一視同仁執(zhí)子之手與子偕老當(dāng)男女主人公含情脈脈看著對(duì)方說了句執(zhí)子之手與子偕老女方淚眼朦朧含羞地回一句討厭啦這樣的情節(jié)我們是不是見過很多但是我們來看看這句的原句死生契闊與子成說執(zhí)子之手與子偕老于嗟闊兮不我活兮于嗟洵兮不我信兮意思是說戰(zhàn)士之間的約定說要一起死現(xiàn)在和我約定的人都走了我怎么活啊赤裸裸的兄弟江湖戰(zhàn)友友誼啊形容好基友的基情比男女之間的愛情要合適很多吧';     //str_split()切割字符串為一個(gè)數(shù)組,一個(gè)中文在utf_8為3個(gè)字符     $strdb = str_split($str,3);         //>11     $captcha_code = '';     //8>生成隨機(jī)的漢子     for($i=0;$i<4;$i++){         //設(shè)置字體顏色,隨機(jī)顏色         $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));            //0-120深顏色         //隨機(jī)選取中文         $in = rand(0,count($strdb));         $cn = $strdb[$in];         //將中文記錄到將保存到session的字符串中         $captcha_code .= $cn;         /*imagettftext (resource $image ,float $size ,float $angle ,int $x ,int $y,int $color,         string $fontfile ,string $text ) 幕布 ,尺寸,角度,坐標(biāo),顏色,字體路徑,文本字符串         mt_rand()生成更好的隨機(jī)數(shù),比rand()快四倍*/         imagettftext($image, mt_rand(20,24),mt_rand(-60,60),(40*$i+20),mt_rand(30,35),$fontcolor,$fontface,$cn);     }     //11>存到session     $_SESSION['authcode'] = $captcha_code;     //9>增加干擾元素,設(shè)置點(diǎn)     for($i=0;$i<200;$i++){         //設(shè)置點(diǎn)的顏色,50-200顏色比數(shù)字淺,不干擾閱讀         $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));                 //imagesetpixel &mdash; 畫一個(gè)單一像素         imagesetpixel($image, rand(1,199), rand(1,59), $pointcolor);     }     //10>增加干擾元素,設(shè)置線     for($i=0;$i<4;$i++){         //設(shè)置線的顏色         $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));         //設(shè)置線,兩點(diǎn)一線         imageline($image,rand(1,199), rand(1,59),rand(1,199), rand(1,59),$linecolor);     }      //2>設(shè)置頭部,image/png     header('Content-Type: image/png');     //3>imagepng() 建立png圖形函數(shù)     imagepng($image);     //4>imagedestroy() 結(jié)束圖形函數(shù)  銷毀$image     imagedestroy($image);

其他的頁(yè)面也是不需要修改的。

效果圖如下:

php中怎么實(shí)現(xiàn)一個(gè)驗(yàn)證碼功能

看完上述內(nèi)容,你們掌握php中怎么實(shí)現(xiàn)一個(gè)驗(yàn)證碼功能的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

新聞名稱:php中怎么實(shí)現(xiàn)一個(gè)驗(yàn)證碼功能
本文路徑:http://muchs.cn/article34/gciope.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站搜索引擎優(yōu)化、關(guān)鍵詞優(yōu)化用戶體驗(yàn)、網(wǎng)站維護(hù)網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)