在PHP中實現登錄功能,通常需要以下幾個步驟:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Login Form</title>
</head>
<body>
<form action="login.php" method="post">
<label for="username">Username:</label>
<input type="text" id="username" name="username" required>
<br>
<label for="password">Password:</label>
<input type="password" id="password" name="password" required>
<br>
<input type="submit" value="Login">
</form>
</body>
</html>
<?php
// 連接到數據庫
$servername = "localhost";
$username = "your_username";
$password = "your_password";
$dbname = "your_database";
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
// 獲取用戶輸入的用戶名和密碼
$username = $_POST['username'];
$password = $_POST['password'];
// 使用預處理語句查詢數據庫
$stmt = $conn->prepare("SELECT * FROM users WHERE username=? AND password=?");
$stmt->bind_param("ss", $username, $password);
$stmt->execute();
$result = $stmt->get_result();
if ($result->num_rows > 0) {
// 用戶名和密碼匹配,登錄成功
session_start();
$_SESSION['loggedin'] = true;
$_SESSION['username'] = $username;
header("Location: dashboard.php");
} else {
// 用戶名或密碼不匹配,登錄失敗
echo "Invalid username or password.";
}
$stmt->close();
$conn->close();
?>
<?php
session_start();
if (!isset($_SESSION['loggedin']) || !$_SESSION['loggedin']) {
header("Location: login.html");
exit();
}
echo "Welcome, " . $_SESSION['username'] . "!";
?>
注意:在實際項目中,為了安全起見,建議使用HTTPS協議,以及對用戶密碼進行哈希處理。此外,還需要考慮SQL注入等安全問題。