溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么用php實現(xiàn)驗證碼登錄

發(fā)布時間:2021-10-15 10:53:29 來源:億速云 閱讀:282 作者:iii 欄目:編程語言

這篇文章主要介紹“怎么用php實現(xiàn)驗證碼登錄”,在日常操作中,相信很多人在怎么用php實現(xiàn)驗證碼登錄問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”怎么用php實現(xiàn)驗證碼登錄”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

php實現(xiàn)驗證碼登錄的方法:1、創(chuàng)建html頁面顯示驗證碼;2、創(chuàng)建php文件,接受前端頁面?zhèn)魅氲尿炞C碼信息;3、創(chuàng)建驗證碼生成PHP文件。

怎么用php實現(xiàn)驗證碼登錄

本文操作環(huán)境:windows10系統(tǒng)、php 7、thinkpad t480電腦。

驗證碼在我們的日常生活中非常常見,使用驗證碼有諸多好處,如:

防止惡意的破解密碼。如一些黑客為了獲取到用戶信息,通過不同的手段向服務(wù)器發(fā)送數(shù)據(jù),驗證猜測用戶信息的準(zhǔn)確性。

防止惡意的刷票,論壇灌水。這種在論壇中長期存在灌水的現(xiàn)象,比如貼吧,不斷發(fā)送帖子。現(xiàn)在百度貼吧已經(jīng)針對用戶發(fā)帖的時間做了一個時間的限制,當(dāng)一定時間內(nèi)發(fā)帖過多是無法繼續(xù)發(fā)帖的。

防止惡意的請求。如用戶提交一個表單信息,通過不斷向后臺請求數(shù)據(jù)信息造成服務(wù)器資源的浪費,以及惡意的攻擊。

趣味性。這一點屬于個人觀點,當(dāng)我們提交表單的時候,如遇到一些有趣的驗證碼方式,能夠增強用戶對網(wǎng)站的喜愛程度。

獲取用戶信息。這一點在現(xiàn)目前的站點中是屢見不鮮的事情了。如我們注冊一個站點的賬號,需要通過手機驗證碼才可以注冊成功。網(wǎng)站在拿到用戶的電話號碼之后會給手機號主發(fā)送一些營銷信息。

那么我們該如何實現(xiàn)驗證碼登錄功能呢?一起來看下吧!

環(huán)境配置:

只需要本地安裝了PHP的GD擴展庫即可使用。如何查看呢,創(chuàng)建一個PHP文件在該文件中寫入<?php phpinfo();?>,訪問該文件,如果查看到了GD庫已經(jīng)安裝了,則可以使用。

具體代碼實現(xiàn):

1、我們先創(chuàng)建一個html頁面顯示驗證碼

<!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="請輸入圖片中的驗證碼"><br/>
        <input type="submit" value="驗證">
    </form>
</body>
</html>

2、創(chuàng)建一個PHP文件,接受前端頁面?zhèn)魅氲尿炞C碼信息

<?php
/**
 * 接受用戶登陸時提交的驗證碼
 */
session_start();
//1. 獲取到用戶提交的驗證碼
$captcha = $_POST["captcha"];
//2. 將session中的驗證碼和用戶提交的驗證碼進(jìn)行核對,當(dāng)成功時提示驗證碼正確,并銷毀之前的session值,不成功則重新提交
if(strtolower($_SESSION["captchaimg"]) == strtolower($captcha)){
    echo "驗證碼正確!";
    $_SESSION["captcha"] = "";
}else{
    echo "驗證碼提交不正確!";
}

3、創(chuàng)建驗證碼生成PHP文件

<?php
/**
 * 字母+數(shù)字的驗證碼生成
 */
// 開啟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è)置驗證碼內(nèi)容
 
//4.1 定義驗證碼的內(nèi)容
$content = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
 
//4.1 創(chuàng)建一個變量存儲產(chǎn)生的驗證碼數(shù)據(jù),便于用戶提交核對
$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.向瀏覽器輸出圖片頭信息
header('content-type:image/png');
 
//6.輸出圖片到瀏覽器
imagepng($image);
 
//7.銷毀圖片
imagedestroy($image); 

到此,關(guān)于“怎么用php實現(xiàn)驗證碼登錄”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI