PHP實現(xiàn)登錄驗證碼校驗功能
驗證碼的校驗是利用PHP中的 SESSION功能來實現(xiàn)。
在最頂端聲明函數(shù) session_start();
告訴服務(wù)器我們要用這個函數(shù)的功能。
session_start();
接下來我們用到的就是驗證碼實現(xiàn)的代碼。這里用英文數(shù)字的代碼為例。
$image = imagecreatetruecolor(100, 30); //創(chuàng)建一個100×30的畫布 $white = imagecolorallocate($image,255,255,255);//白色 imagefill($image,0,0,$white);//覆蓋黑色畫布
然后在驗證碼實現(xiàn)之前聲明一個空變量,用來存放驗證碼。
$session = ""; //空變量 ,存放驗證碼 for($i=0;$i<4;$i++){ $size = 6; $x = $i*25+mt_rand(5,10); $y = mt_rand(5,10); $sizi_color = imagecolorallocate($image,mt_rand(80,220),mt_rand(80,220),mt_rand(80,220)); $char = join("",array_merge(range('a','z'),range('A','Z'),range(0,9))); $char = str_shuffle($char); $char = substr($char,0,1); imagestring($image,$size,$x,$y,$char,$sizi_color); $session .= $char ; //把驗證碼的每一個值賦值給變量 } $_SESSION['session'] = $session; //這個變量的值與用戶輸入的值相等 for($k=0;$k<200;$k++){ $rand_color = imagecolorallocate($image,mt_rand(50,200),mt_rand(50,200),mt_rand(50,200)); imagesetpixel($image,mt_rand(1,99),mt_rand(1,29),$rand_color); } for($n=0;$n<5;$n++){ $line_color = imagecolorallocate($image,mt_rand(80,220),mt_rand(80,220),mt_rand(80,220)); imageline($image,mt_rand(1,99),mt_rand(1,29),mt_rand(1,99),mt_rand(1,29),$line_color); } header('content-type:image/png');//設(shè)置文件輸出格式 imagepng( $image ); //以png格式輸出$image圖像 imagedestroy( $image ); //銷毀圖像
用 POST 方式來接收驗證碼。 strtolower 函數(shù)是讓服務(wù)器不區(qū)分大小寫。這樣可以有效減少用戶的輸錯率。
if(isset($_POST['session'])){ session_start(); if(strtolower($_POST['session'])==strtolower($_SESSION['session'])){ echo'<font color="#0000CC">輸入正確</form>'; }else{ echo '<font color="#CC0000"><b>輸入錯誤</b></font>'; } exit(); }
下面是HTML的頁面代碼。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <title>確認(rèn)驗證碼</title> </head> <body> <form method="post" action="./tushu.php"> <p>驗證碼圖片:<img id="img" border="1" src="http://localhost//xxx.php" width="100" height="30"></p> <a href="javascript:void(0)" rel="external nofollow" onclick="document.getElementById('img').src='http://localhost//xxx.php'">看不清?換一個</a> <p>請輸入圖片中的驗證碼:<input type="text" name="session" value=""/></p> <p><input type="submit" value="提交" style="padding:6px 10px;"></p> </form> </body> </html>
總結(jié)
以上所述是小編給大家介紹的PHP實現(xiàn)登錄驗證碼校驗功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- php cookie 登錄驗證示例代碼
- PHP通過session id 實現(xiàn)session共享和登錄驗證的代碼
- php session應(yīng)用實例 登錄驗證
- 簡單的方法讓你的后臺登錄更加安全(php中加session驗證)
- php+MySQL實現(xiàn)登錄時驗證登錄名和密碼是否正確
- PHP登錄驗證碼的實現(xiàn)與使用方法
- php自動注冊登錄驗證機(jī)制實現(xiàn)代碼
- PHP+Ajax驗證碼驗證用戶登錄
- PHP登錄驗證功能示例【用戶名、密碼、驗證碼、數(shù)據(jù)庫、已登陸驗證、自動登錄和注銷登錄等】
- PHP編寫登錄驗證碼功能 附調(diào)用方法
- php面向?qū)ο蟮挠脩舻卿浬矸蒡炞C
- PHP 實現(xiàn)超簡單的SESSION與COOKIE登錄驗證功能示例
相關(guān)文章
PHP的Laravel框架中使用消息隊列queue及異步隊列的方法
這篇文章主要介紹了PHP的Laravel框架中使用消息隊列queue及異步隊列的方法,針對Laravel 5.0后的版本,示例環(huán)境為Linux系統(tǒng),需要的朋友可以參考下2016-03-03PHP實現(xiàn)的漢字拼音轉(zhuǎn)換和公歷農(nóng)歷轉(zhuǎn)換類及使用示例
這篇文章主要介紹了PHP實現(xiàn)的漢字拼音轉(zhuǎn)換和公歷農(nóng)歷轉(zhuǎn)換類及使用示例,精心整理自網(wǎng)上的資源,需要的朋友可以參考下2014-07-07Laravel框架基于中間件實現(xiàn)禁止未登錄用戶訪問頁面功能示例
這篇文章主要介紹了Laravel框架基于中間件實現(xiàn)禁止未登錄用戶訪問頁面功能,結(jié)合實例形式分析了Laravel框架中間件生成、注冊及使用相關(guān)操作技巧,需要的朋友可以參考下2019-01-01GD庫實現(xiàn)webp轉(zhuǎn)換jpg的PHP程序
PHP程序來執(zhí)行webp格式轉(zhuǎn)換成jpg格式有幾種方法:一是安裝imagemagick實現(xiàn),二是安裝GD庫實現(xiàn),可以直接用dwebp命令,本文我們將介紹使用PHP的圖像處理庫GD,編寫一個簡單的PHP程序來完成這個任務(wù)2024-03-03tp5 實現(xiàn)列表數(shù)據(jù)根據(jù)狀態(tài)排序
今天小編就為大家分享一篇tp5 實現(xiàn)列表數(shù)據(jù)根據(jù)狀態(tài)排序,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10Yii2框架引用bootstrap中日期插件yii2-date-picker的方法
這篇文章主要介紹了Yii2框架引用bootstrap中日期插件yii2-date-picker的方法,實例分析了yii2-date-picker插件的具體使用步驟與相關(guān)技巧,需要的朋友可以參考下2016-01-01