php实现登录功能
PHP 登录功能实现
使用 PHP 实现登录功能需要结合数据库验证和会话管理。以下是一个完整的实现方法:
数据库准备
创建一个用户表存储用户名和密码(建议使用哈希存储):
CREATE TABLE users (
id INT AUTO_INCREMENT PRIMARY KEY,
username VARCHAR(50) NOT NULL UNIQUE,
password VARCHAR(255) NOT NULL,
created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);
登录表单
创建 HTML 登录表单(login.php):

<form action="authenticate.php" method="post">
<label for="username">用户名:</label>
<input type="text" id="username" name="username" required>
<label for="password">密码:</label>
<input type="password" id="password" name="password" required>
<button type="submit">登录</button>
</form>
认证处理
创建认证脚本(authenticate.php):
<?php
session_start();
$db = new PDO('mysql:host=localhost;dbname=your_db', 'username', 'password');
$username = $_POST['username'];
$password = $_POST['password'];
$stmt = $db->prepare("SELECT id, password FROM users WHERE username = ?");
$stmt->execute([$username]);
$user = $stmt->fetch();
if ($user && password_verify($password, $user['password'])) {
$_SESSION['user_id'] = $user['id'];
header('Location: dashboard.php');
exit;
} else {
echo "无效的用户名或密码";
}
?>
密码哈希
注册时应使用 password_hash() 存储密码:

$hashedPassword = password_hash($plainPassword, PASSWORD_DEFAULT);
会话验证
受保护页面(dashboard.php)验证会话:
<?php
session_start();
if (!isset($_SESSION['user_id'])) {
header('Location: login.php');
exit;
}
?>
<!-- 受保护内容 -->
安全增强
- 使用预处理语句防止 SQL 注入
- 启用 HTTPS 传输
- 设置会话安全参数:
ini_set('session.cookie_httponly', 1); ini_set('session.cookie_secure', 1); session_regenerate_id(true);
注销功能
实现注销(logout.php):
<?php
session_start();
session_destroy();
header('Location: login.php');
?>
这个实现包含了用户认证的基本要素,可根据具体需求添加密码重置、记住我等额外功能。






