您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)php實(shí)現(xiàn)登錄驗(yàn)證碼的方法的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過來看看吧。
php實(shí)現(xiàn)登錄驗(yàn)證碼的方法:首先產(chǎn)生4到6位數(shù)的隨機(jī)驗(yàn)證碼;然后把產(chǎn)生的每個(gè)字符保存到session或數(shù)據(jù)庫;接著將驗(yàn)證碼發(fā)送到用戶的手機(jī);最后將和輸入的驗(yàn)證碼進(jìn)行對(duì)比驗(yàn)證即可。
PHP實(shí)現(xiàn)簡單的驗(yàn)證碼功能機(jī)制
網(wǎng)站的安全性是開發(fā)者不可忽視的一個(gè)問題,目前使用最多的一種可以提高網(wǎng)站安全性的方法就是使用驗(yàn)證碼功能機(jī)制,有的僅僅使用一個(gè)幾位數(shù)字字母混亂的驗(yàn)證碼,有的進(jìn)行手機(jī)發(fā)送短信進(jìn)行驗(yàn)證,有的使用郵箱發(fā)送郵件進(jìn)行驗(yàn)證,但是這個(gè)驗(yàn)證碼功能機(jī)制是如何實(shí)現(xiàn)的呢?下面就為大家詳細(xì)解釋驗(yàn)證碼功能機(jī)制的實(shí)現(xiàn)思路以及簡單的實(shí)現(xiàn)方法。
1、驗(yàn)證碼功能機(jī)制實(shí)現(xiàn)思路
① 常規(guī)的驗(yàn)證碼實(shí)現(xiàn):
a、產(chǎn)生一張png的圖片
b、為圖片設(shè)置背景色
c、設(shè)置字體顏色和樣式
d、產(chǎn)生4位數(shù)的隨機(jī)的驗(yàn)證碼
e、把產(chǎn)生的每個(gè)字符調(diào)整旋轉(zhuǎn)角度和位置畫到png圖片上
f、加入噪點(diǎn)和干擾線防止注冊(cè)機(jī)器分析原圖片來惡意注冊(cè)
g、輸出圖片
h、釋放圖片所占內(nèi)存
i、將驗(yàn)證碼保存到session或是數(shù)據(jù)庫
j、將和輸入的驗(yàn)證碼進(jìn)行對(duì)比
② 短信(郵箱)驗(yàn)證碼機(jī)制:
a、產(chǎn)生4-6位數(shù)的隨機(jī)的驗(yàn)證碼
b、把產(chǎn)生的每個(gè)字符保存到session或是數(shù)據(jù)庫
c、將驗(yàn)證碼發(fā)送到用戶的手機(jī)(郵箱)
d、用戶在規(guī)定時(shí)間內(nèi)進(jìn)行輸入
e、將驗(yàn)證碼從session或是數(shù)據(jù)庫中取出
f、將和輸入的驗(yàn)證碼進(jìn)行對(duì)比驗(yàn)證
2、簡單的實(shí)現(xiàn)驗(yàn)證碼功能機(jī)制
① 新建captcha.php,寫入以下代碼
<?php /** * ======================================= * Created by WeiBang Technology. * User: Wei ZhiHua * Date: 2016/10/12 0020 * Time: 下午 4:14 * Power: 實(shí)現(xiàn)驗(yàn)證碼功能 * ======================================= */ //開啟session session_start(); //創(chuàng)建一個(gè)大小為 100*30 的驗(yàn)證碼 $image = imagecreatetruecolor(100, 30); $bgcolor = imagecolorallocate($image, 255, 255, 255); imagefill($image, 0, 0, $bgcolor); $captch_code = ''; for ($i = 0; $i < 4; $i++) { $fontsize = 6; $fontcolor = imagecolorallocate($image, rand(0, 120), rand(0, 120), rand(0, 120)); $data = 'abcdefghijkmnpqrstuvwxy3456789'; $fontcontent = substr($data, rand(0, strlen($data) - 1), 1); $captch_code .= $fontcontent; $x = ($i * 100 / 4) + rand(5, 10); $y = rand(5, 10); imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor); } //就生成的驗(yàn)證碼保存到session $_SESSION['authcode'] = $captch_code; //在圖片上增加點(diǎn)干擾元素 for ($i = 0; $i < 200; $i++) { $pointcolor = imagecolorallocate($image, rand(50, 200), rand(50, 200), rand(50, 200)); imagesetpixel($image, rand(1, 99), rand(1, 29), $pointcolor); } //在圖片上增加線干擾元素 for ($i = 0; $i < 3; $i++) { $linecolor = imagecolorallocate($image, rand(80, 220), rand(80, 220), rand(80, 220)); imageline($image, rand(1, 99), rand(1, 29), rand(1, 99), rand(1, 29), $linecolor); } //設(shè)置頭 header('content-type:image/png'); imagepng($image); imagedestroy($image); ?>
② 新建form.php,寫入以下代碼
<?php /** * ======================================= * Created by WeiBang Technology. * User: Wei ZhiHua * Date: 2016/10/12 0021 * Time: 下午 4:14 * Power: 實(shí)現(xiàn)驗(yàn)證碼功能 * ======================================= */ if (isset($_REQUEST['authcode'])) { session_start(); if (strtolower($_REQUEST['authcode']) == $_SESSION['authcode']) { echo "輸入正確!"; } else { echo "輸入錯(cuò)誤!"; } exit(); } ?> <!DOCTYPE html> <html> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8"/> <title>確認(rèn)驗(yàn)證碼</title> </head> <body> <form method="post" action="./form.php"> <p>驗(yàn)證碼圖片: <img id="captcha_img" border="1" src="./captcha.php?r=<?php echo rand(); ?>" width=100 height=30> <a href="javascript:void(0)" onClick="document.getElementById('captcha_img').src='./captcha.php?r='+Math.random()">換一個(gè)?</a> </p> <p>請(qǐng)輸入圖片中的內(nèi)容:<input type="text" name="authcode" value=""/></p> <p><input type="submit" value="提交" style="padding:6px 20px;"></p> </form> </body> </html>
感謝各位的閱讀!關(guān)于php實(shí)現(xiàn)登錄驗(yàn)證碼的方法就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。