很少會發現一個有吸引力的網站不建議客戶建立帳戶。為此,他們需要為新用戶提供自行註冊的設施,然後使用其帳戶登入並與網站互動。 PHP 公開了足夠的實用程式來快速設定功能性登入頁面,並且稍後還可以根據需要進行擴充。設定基本登入表單來請求憑證後,可以使用相同的 PHP 腳本來處理和驗證憑證,並在成功登入時重定向到對應的頁面。它還提供了創建和儲存 cookie 和會話的選項,以便在使用者完成登入程序後追蹤使用者。
廣告 該類別中的熱門課程 PHP 開發人員 - 專業化 | 8 門課程系列 | 3次模擬測驗開始您的免費軟體開發課程
網頁開發、程式語言、軟體測試及其他
PHP 是一種可擴充的無狀態伺服器端腳本語言。它允許人們透過將表單資料儲存在數組 $_GET 或 $_POST 中來捕獲表單數據,這取決於提交表單時使用的方法是 GET 還是 POST。通常,出於安全原因,首選 post 方法。提交後,這些數組可以透過輸入欄位名稱進行索引來取得具體值。
對於登入表單,憑證會被傳遞並儲存在這些陣列中,這些陣列通常只是一組使用者名稱和密碼。根據需求,可以在 PHP 程式碼本身中直接驗證使用者名稱和密碼組合,或者可以將有效的使用者名稱、密碼組合集儲存在可以找到的資料庫中。
讓我們建立一個頁面 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>
輸出:
這些行建立了一個非常簡單的表單,要求使用者輸入兩個欄位:使用者名稱和密碼。它提供第三個輸入,即提交按鈕,並導致表單資料(即使用者名稱和密碼)發送到表單標記的操作屬性中提到的位置。由於上面是空的,所以它將表單資訊傳遞到同一個 PHP 頁面。
上面的頁面是靜態 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()不會建立新的會話,而是檢索先前啟動的會話的信息,並將其儲存在一個特殊的陣列$_SESSION中。
會話處於活動狀態時跨頁面傳遞的值可以以與普通數組類似的方式設置,並且 isset() 函數可用於檢查數組中是否存在特定值。
結合所有討論的內容,程式碼將如下所示:
代碼:
輸出:
現在,任何其他需要登入的頁面只需要檢查會話金鑰登入是否已設定。如果沒有,使用者可以被重新導向到登入頁面。否則他就可以存取秘密的內部內容。
讓我們建立一個用於演示目的:
代碼:
<?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() 來檢索會話詳細資訊。然後,它驗證會話對於已完成登入程序的使用者仍然處於活動狀態。如果沒有,使用者將被傳送到 Login.php 頁面。如果使用者已成功登錄,則其餘內容可供使用者使用。
用 PHP 建立登入頁面非常容易。在這裡,我們直接將憑證儲存在腳本中,但理想情況下(也是最常見的)它們將儲存在某種形式的資料庫或金鑰管理員中。另外,這裡我們使用了會話,它儲存在瀏覽器端,但您可以使用儲存在瀏覽器(客戶端)端但不太可靠的 cookie。
以上是PHP 中的登入頁面的詳細內容。更多資訊請關注PHP中文網其他相關文章!