很少會發(fā)現一個有吸引力的網站不建議客戶創(chuàng)建帳戶。為此,他們需要為新用戶提供自行注冊的設施,然后使用其帳戶登錄并與網站交互。 PHP 公開了足夠的實用程序來快速設置功能性登錄頁面,并且稍后還可以根據需要進行擴展。設置基本登錄表單來請求憑據后,可以使用相同的 PHP 腳本來處理和驗證憑據,并在成功登錄時重定向到相應的頁面。它還提供了創(chuàng)建和存儲 cookie 和會話的選項,以便在用戶完成登錄過程后跟蹤用戶。
廣告
該類別中的熱門課程
PHP 開發(fā)人員 - 專業(yè)化 | 8 門課程系列 | 3次模擬測試
開始您的免費軟件開發(fā)課程
網絡開發(fā)、編程語言、軟件測試及其他
PHP 中的登錄頁面如何工作?
PHP 是一種可擴展的無狀態(tài)服務器端腳本語言。它允許人們通過將表單數據存儲在數組 $_GET 或 $_POST 中來捕獲表單數據,具體取決于提交表單時使用的方法是 GET 還是 POST。通常,出于安全原因,首選 post 方法。提交后,這些數組可以通過輸入字段名稱進行索引來獲取具體值。
對于登錄表單,憑據被傳遞并存儲在這些數組中,這些數組通常只是一組用戶名和密碼。根據需求,可以在 PHP 代碼本身中直接驗證用戶名和密碼組合,或者可以將有效的用戶名、密碼組合集存儲在可以查找的數據庫中。
設置登錄頁面
讓我們創(chuàng)建一個頁面 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>
輸出:

這些行創(chuàng)建了一個非常簡單的表單,要求用戶輸入兩個字段:用戶名和密碼。它提供第三個輸入,即提交按鈕,并導致表單數據(即用戶名和密碼)發(fā)送到表單標記的操作屬性中提到的位置。由于上面是空的,所以它將表單信息傳遞到同一個 PHP 頁面。
如何用 PHP 創(chuàng)建登錄頁面?
上面的頁面是靜態(tài) HTML 代碼,沒有實際驗證用戶或將用戶登錄到內部網頁。為此,我們需要處理存儲在 $_POST 中的 username 和 pwd 字段中傳遞的值,因為使用了 posts 方法。
因此可以使用以下方法檢查是否存在值:
代碼:
<?php
$error = "";
if(isset($_POST['username']) && isset($_POST['pwd'])){
// check for validity
}
?>
驗證兩個輸入確實存在后,我們可以驗證它們的值并將人員重定向到適當的歡迎頁面。
我們可以通過在上面所示的 if 語句塊中插入以下簡單的代碼來實現此目的:
代碼:
$username = $_POST['username'];
$password = $_POST['pwd'];
if($username == "admin" && $password == "l0G3In"){
header('location: Home.php');
}
else {
$error = "Invalid username or password!";
}
通過上述幾行,一旦用戶提交了一組有效的憑據,他就可以訪問 home.php,或者我們存儲一條可以向用戶顯示的錯誤消息。
會議
我們不希望用戶在每次請求時都重復登錄。因此,我們需要跟蹤已登錄的用戶,無論他們請求哪個頁面。在 PHP 中實現此目的的一種方法是使用會話。
簡單來說,會話??是服務器端的一小段信息,在請求頁面后為客戶端臨時存儲。在 PHP 中,這是通過調用函數 session_start() 作為腳本中的第一行來實現的。從下次訪問頁面開始,session_start()不會創(chuàng)建新的會話,而是檢索之前啟動的會話的信息,并將其存儲在一個特殊的數組$_SESSION中。
會話處于活動狀態(tài)時跨頁面?zhèn)鬟f的值可以以與普通數組類似的方式設置,并且 isset() 函數可用于檢查數組中是否存在特定值。
結合所有討論的內容,代碼將如下所示:
代碼:
A sample login page
Enter Login Information:
輸出:

Home.php
現在,任何其他需要登錄的頁面只需要檢查會話密鑰登錄是否已設置。如果沒有,用戶可以被重定向到登錄頁面。否則他就可以訪問秘密的內部內容。
讓我們創(chuàng)建一個用于演示目的:
代碼:
<?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() 來檢索會話詳細信息。然后,它驗證會話對于已完成登錄過程的用戶仍然處于活動狀態(tài)。如果沒有,用戶將被發(fā)送到 Login.php 頁面。如果用戶已成功登錄,則其余內容可供用戶使用。
結論
用 PHP 創(chuàng)建登錄頁面非常容易。在這里,我們直接將憑據存儲在腳本中,但理想情況下(也是最常見的)它們將存儲在某種形式的數據庫或密鑰管理器中。另外,這里我們使用了會話,它存儲在瀏覽器端,但是您可以使用存儲在瀏覽器(客戶端)端但不太可靠的 cookie。
以上是PHP 中的登錄頁面的詳細內容。更多信息請關注PHP中文網其他相關文章!