php實(shí)現(xiàn)驗(yàn)證碼登錄的方法:1、創(chuàng)建html頁面顯示驗(yàn)證碼;2、創(chuàng)建php文件,接受前端頁面?zhèn)魅氲尿?yàn)證碼信息;3、創(chuàng)建驗(yàn)證碼生成PHP文件。
本文操作環(huán)境:windows10系統(tǒng)、php 7、thinkpad t480電腦。
驗(yàn)證碼在我們的日常生活中非常常見,使用驗(yàn)證碼有諸多好處,如:
防止惡意的破解密碼。如一些黑客為了獲取到用戶信息,通過不同的手段向服務(wù)器發(fā)送數(shù)據(jù),驗(yàn)證猜測用戶信息的準(zhǔn)確性。
防止惡意的刷票,論壇灌水。這種在論壇中長期存在灌水的現(xiàn)象,比如貼吧,不斷發(fā)送帖子?,F(xiàn)在百度貼吧已經(jīng)針對(duì)用戶發(fā)帖的時(shí)間做了一個(gè)時(shí)間的限制,當(dāng)一定時(shí)間內(nèi)發(fā)帖過多是無法繼續(xù)發(fā)帖的。
防止惡意的請(qǐng)求。如用戶提交一個(gè)表單信息,通過不斷向后臺(tái)請(qǐng)求數(shù)據(jù)信息造成服務(wù)器資源的浪費(fèi),以及惡意的攻擊。
趣味性。這一點(diǎn)屬于個(gè)人觀點(diǎn),當(dāng)我們提交表單的時(shí)候,如遇到一些有趣的驗(yàn)證碼方式,能夠增強(qiáng)用戶對(duì)網(wǎng)站的喜愛程度。
獲取用戶信息。這一點(diǎn)在現(xiàn)目前的站點(diǎn)中是屢見不鮮的事情了。如我們注冊(cè)一個(gè)站點(diǎn)的賬號(hào),需要通過手機(jī)驗(yàn)證碼才可以注冊(cè)成功。網(wǎng)站在拿到用戶的電話號(hào)碼之后會(huì)給手機(jī)號(hào)主發(fā)送一些營銷信息。
那么我們?cè)撊绾螌?shí)現(xiàn)驗(yàn)證碼登錄功能呢?一起來看下吧!
環(huán)境配置:
只需要本地安裝了PHP的GD擴(kuò)展庫即可使用。如何查看呢,創(chuàng)建一個(gè)PHP文件在該文件中寫入<?php phpinfo();?>,訪問該文件,如果查看到了GD庫已經(jīng)安裝了,則可以使用。
具體代碼實(shí)現(xiàn):
1、我們先創(chuàng)建一個(gè)html頁面顯示驗(yàn)證碼
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>登陸</title> </head> <body> <form action="./login.php" method="post"> <img src="image_captcha.php" onclick="this.src='image_captcha.php?'+new Date().getTime();" width="200" height="200"><br/> <input type="text" name="captcha" placeholder="請(qǐng)輸入圖片中的驗(yàn)證碼"><br/> <input type="submit" value="驗(yàn)證"> </form> </body> </html>
2、創(chuàng)建一個(gè)PHP文件,接受前端頁面?zhèn)魅氲尿?yàn)證碼信息
<?php /** * 接受用戶登陸時(shí)提交的驗(yàn)證碼 */ session_start(); //1. 獲取到用戶提交的驗(yàn)證碼 $captcha = $_POST["captcha"]; //2. 將session中的驗(yàn)證碼和用戶提交的驗(yàn)證碼進(jìn)行核對(duì),當(dāng)成功時(shí)提示驗(yàn)證碼正確,并銷毀之前的session值,不成功則重新提交 if(strtolower($_SESSION["captchaimg"]) == strtolower($captcha)){ echo "驗(yàn)證碼正確!"; $_SESSION["captcha"] = ""; }else{ echo "驗(yàn)證碼提交不正確!"; }
3、創(chuàng)建驗(yàn)證碼生成PHP文件
<?php /** * 字母+數(shù)字的驗(yàn)證碼生成 */ // 開啟session session_start(); //1.創(chuàng)建黑色畫布 $image = imagecreatetruecolor(100, 30); //2.為畫布定義(背景)顏色 $bgcolor = imagecolorallocate($image, 255, 255, 255); //3.填充顏色 imagefill($image, 0, 0, $bgcolor); // 4.設(shè)置驗(yàn)證碼內(nèi)容 //4.1 定義驗(yàn)證碼的內(nèi)容 $content = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; //4.1 創(chuàng)建一個(gè)變量存儲(chǔ)產(chǎn)生的驗(yàn)證碼數(shù)據(jù),便于用戶提交核對(duì) $captcha = ""; for ($i = 0; $i < 4; $i++) { // 字體大小 $fontsize = 10; // 字體顏色 $fontcolor = imagecolorallocate($image, mt_rand(0, 120), mt_rand(0, 120), mt_rand(0, 120)); // 設(shè)置字體內(nèi)容 $fontcontent = substr($content, mt_rand(0, strlen($content)), 1); $captcha .= $fontcontent; // 顯示的坐標(biāo) $x = ($i * 100 / 4) + mt_rand(5, 10); $y = mt_rand(5, 10); // 填充內(nèi)容到畫布中 imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor); } $_SESSION["captcha"] = $captcha; //4.3 設(shè)置背景干擾元素 for ($$i = 0; $i < 200; $i++) { $pointcolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200)); imagesetpixel($image, mt_rand(1, 99), mt_rand(1, 29), $pointcolor); } //4.4 設(shè)置干擾線 for ($i = 0; $i < 3; $i++) { $linecolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200)); imageline($image, mt_rand(1, 99), mt_rand(1, 29), mt_rand(1, 99), mt_rand(1, 29), $linecolor); } //5.向?yàn)g覽器輸出圖片頭信息 header('content-type:image/png'); //6.輸出圖片到瀏覽器 imagepng($image); //7.銷毀圖片 imagedestroy($image);
推薦學(xué)習(xí):php培訓(xùn)