很少會(huì)發(fā)現(xiàn)一個(gè)有吸引力的網(wǎng)站不建議客戶建立帳戶。為此,他們需要為新用戶提供自行註冊的設(shè)施,然後使用其帳戶登入並與網(wǎng)站互動(dòng)。 PHP 公開了足夠的實(shí)用程式來快速設(shè)定功能性登入頁面,並且稍後還可以根據(jù)需要進(jìn)行擴(kuò)充。設(shè)定基本登入表單來請求憑證後,可以使用相同的 PHP 腳本來處理和驗(yàn)證憑證,並在成功登入時(shí)重定向到對應(yīng)的頁面。它還提供了創(chuàng)建和儲(chǔ)存 cookie 和會(huì)話的選項(xiàng),以便在使用者完成登入程序後追蹤使用者。
廣告
該類別中的熱門課程
PHP 開發(fā)人員 - 專業(yè)化 | 8 門課程系列 | 3次模擬測驗(yàn)
開始您的免費(fèi)軟體開發(fā)課程
網(wǎng)頁開發(fā)、程式語言、軟體測試及其他
PHP 中的登入頁面如何運(yùn)作?
PHP 是一種可擴(kuò)充的無狀態(tài)伺服器端腳本語言。它允許人們透過將表單資料儲(chǔ)存在數(shù)組 $_GET 或 $_POST 中來捕獲表單數(shù)據(jù),這取決於提交表單時(shí)使用的方法是 GET 還是 POST。通常,出於安全原因,首選 post 方法。提交後,這些數(shù)組可以透過輸入欄位名稱進(jìn)行索引來取得具體值。
對於登入表單,憑證會(huì)被傳遞並儲(chǔ)存在這些陣列中,這些陣列通常只是一組使用者名稱和密碼。根據(jù)需求,可以在 PHP 程式碼本身中直接驗(yàn)證使用者名稱和密碼組合,或者可以將有效的使用者名稱、密碼組合集儲(chǔ)存在可以找到的資料庫中。
設(shè)定登入頁面
讓我們建立一個(gè)頁面 Login.php,其中包含以下 HTML 行:
代碼:
<html>
<head>A sample login page</head>
<body>
<h2>Enter Login Information:</h2><br>
<form action="" method="post">
<label>Username : </label><input type="text" name="username" /><br/>
<label>Password : </label><input type="password" name="pwd" /><br/>
<input type="submit" value="Login" />
</form>
</body>
</html>
輸出:

這些行建立了一個(gè)非常簡單的表單,要求使用者輸入兩個(gè)欄位:使用者名稱和密碼。它提供第三個(gè)輸入,即提交按鈕,並導(dǎo)致表單資料(即使用者名稱和密碼)發(fā)送到表單標(biāo)記的操作屬性中提到的位置。由於上面是空的,所以它將表單資訊傳遞到同一個(gè) PHP 頁面。
如何用 PHP 建立登入頁面?
上面的頁面是靜態(tài) HTML 程式碼,沒有實(shí)際驗(yàn)證使用者或?qū)⑹褂谜叩侨雰?nèi)部網(wǎng)頁。為此,我們需要處理儲(chǔ)存在 $_POST 中的 username 和 pwd 欄位中傳遞的值,因?yàn)槭褂昧?posts 方法。
因此可以使用以下方法檢查是否存在值:
代碼:
<?php
$error = "";
if(isset($_POST['username']) && isset($_POST['pwd'])){
// check for validity
}
?>
驗(yàn)證兩個(gè)輸入確實(shí)存在後,我們可以驗(yàn)證它們的值並將人員重定向到適當(dāng)?shù)臍g迎頁面。
我們可以透過在上面所示的 if 語句區(qū)塊中插入以下簡單的程式碼來實(shí)現(xiàn)此目的:
代碼:
$username = $_POST['username'];
$password = $_POST['pwd'];
if($username == "admin" && $password == "l0G3In"){
header('location: Home.php');
}
else {
$error = "Invalid username or password!";
}
透過上述幾行,一旦使用者提交了一組有效的憑證,他就可以存取 home.php,或者我們儲(chǔ)存一條可以向使用者顯示的錯(cuò)誤訊息。
會(huì)議
我們不希望使用者在每次請求時(shí)都重複登入。因此,我們需要追蹤已登入的用戶,無論他們請求哪個(gè)頁面。在 PHP 中實(shí)現(xiàn)此目的的一種方法是使用會(huì)話。
簡單來說,會(huì)話是伺服器端的一小段訊息,在請求頁面後為客戶端臨時(shí)儲(chǔ)存。在 PHP 中,這是透過呼叫函數(shù) session_start() 作為腳本中的第一行來實(shí)現(xiàn)的。從下次訪問頁面開始,session_start()不會(huì)建立新的會(huì)話,而是檢索先前啟動(dòng)的會(huì)話的信息,並將其儲(chǔ)存在一個(gè)特殊的陣列$_SESSION中。
會(huì)話處於活動(dòng)狀態(tài)時(shí)跨頁面?zhèn)鬟f的值可以以與普通數(shù)組類似的方式設(shè)置,並且 isset() 函數(shù)可用於檢查數(shù)組中是否存在特定值。
結(jié)合所有討論的內(nèi)容,程式碼將如下所示:
代碼:
A sample login page
Enter Login Information:
輸出:

Home.php
現(xiàn)在,任何其他需要登入的頁面只需要檢查會(huì)話金鑰登入是否已設(shè)定。如果沒有,使用者可以被重新導(dǎo)向到登入頁面。否則他就可以存取秘密的內(nèi)部內(nèi)容。
讓我們建立一個(gè)用於演示目的:
代碼:
<?php
session_start();
if(!isset($_SESSION["login"]) || $_SESSION["login"]!=True){
header('location: Login.php');
}
?>
<html>
<head>Welcome to User's Home Page</head>
<body>
<h2>Wishing you a good day!!</h2><br>
</body>
</html>
輸出:

上面的程式碼首先透過呼叫 session_start() 來檢索會(huì)話詳細(xì)資訊。然後,它驗(yàn)證會(huì)話對於已完成登入程序的使用者仍然處於活動(dòng)狀態(tài)。如果沒有,使用者將被傳送到 Login.php 頁面。如果使用者已成功登錄,則其餘內(nèi)容可供使用者使用。
結(jié)論
用 PHP 建立登入頁面非常容易。在這裡,我們直接將憑證儲(chǔ)存在腳本中,但理想情況下(也是最常見的)它們將儲(chǔ)存在某種形式的資料庫或金鑰管理員中。另外,這裡我們使用了會(huì)話,它儲(chǔ)存在瀏覽器端,但您可以使用儲(chǔ)存在瀏覽器(客戶端)端但不太可靠的 cookie。
以上是PHP 中的登入頁面的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!