当前位置:首页 > PHP

php实现登录小项目

2026-04-03 04:58:01PHP

环境准备

确保已安装PHP(建议7.4+版本)和MySQL数据库。推荐使用集成环境如XAMPP或WAMP简化配置。

数据库设计

创建用户表存储登录信息:

CREATE TABLE `users` (
  `id` INT AUTO_INCREMENT PRIMARY KEY,
  `username` VARCHAR(50) NOT NULL UNIQUE,
  `password` VARCHAR(255) NOT NULL,
  `created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

注册功能实现

创建注册表单register.php

<form action="register_process.php" method="post">
  <input type="text" name="username" placeholder="用户名" required>
  <input type="password" name="password" placeholder="密码" required>
  <button type="submit">注册</button>
</form>

处理注册逻辑register_process.php

<?php
$conn = new mysqli('localhost', 'root', '', 'auth_demo');
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
  $username = $_POST['username'];
  $password = password_hash($_POST['password'], PASSWORD_DEFAULT);

  $stmt = $conn->prepare("INSERT INTO users (username, password) VALUES (?, ?)");
  $stmt->bind_param("ss", $username, $password);
  $stmt->execute();

  header("Location: login.php");
  exit();
}
?>

登录功能实现

创建登录表单login.php

<form action="login_process.php" method="post">
  <input type="text" name="username" placeholder="用户名" required>
  <input type="password" name="password" placeholder="密码" required>
  <button type="submit">登录</button>
</form>

处理登录逻辑login_process.php

<?php
session_start();
$conn = new mysqli('localhost', 'root', '', 'auth_demo');

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
  $username = $_POST['username'];
  $password = $_POST['password'];

  $stmt = $conn->prepare("SELECT id, password FROM users WHERE username = ?");
  $stmt->bind_param("s", $username);
  $stmt->execute();
  $result = $stmt->get_result();

  if ($result->num_rows === 1) {
    $user = $result->fetch_assoc();
    if (password_verify($password, $user['password'])) {
      $_SESSION['user_id'] = $user['id'];
      header("Location: dashboard.php");
      exit();
    }
  }
  echo "登录失败";
}
?>

会话管理

创建受保护页面dashboard.php

<?php
session_start();
if (!isset($_SESSION['user_id'])) {
  header("Location: login.php");
  exit();
}
?>
<h1>欢迎进入仪表盘</h1>
<a href="logout.php">退出登录</a>

退出登录处理logout.php

<?php
session_start();
session_destroy();
header("Location: login.php");
exit();
?>

安全增强

在数据库连接后添加错误检查:

if ($conn->connect_error) {
  die("连接失败: " . $conn->connect_error);
}

对所有用户输入进行过滤:

php实现登录小项目

$username = filter_input(INPUT_POST, 'username', FILTER_SANITIZE_STRING);

该实现包含完整注册/登录流程,使用预处理语句防止SQL注入,password_hash()安全存储密码,会话机制管理用户状态。可根据需要添加验证码、记住我等功能扩展安全性。

标签: 项目php
分享给朋友:

相关文章

php实现登录

php实现登录

PHP 登录功能实现 数据库连接与用户表创建 创建一个数据库连接文件 db.php,用于管理数据库连接。MySQL 示例代码如下: <?php $host = 'localhost'; $db…

php购物车实现

php购物车实现

PHP购物车实现方法 使用PHP实现购物车功能可以通过多种方式完成,以下是几种常见的实现方法: Session存储购物车数据 利用PHP的$_SESSION超全局变量存储购物车数据是最简单的方法。用…

php实现博客

php实现博客

使用PHP实现博客系统 数据库设计 创建数据库表存储博客文章和用户信息。常见的表包括posts(文章)和users(用户)。 CREATE TABLE users ( id INT AUTO…

php实现的进度条

php实现的进度条

PHP 实现的进度条方法 在 PHP 中实现进度条通常可以通过命令行脚本(CLI)或 Web 页面两种方式完成。以下是几种常见的实现方法: 命令行进度条 使用 PHP CLI 实现进度条,可以通过不…

php实现mvc

php实现mvc

PHP 实现 MVC 架构 MVC(Model-View-Controller)是一种常用的软件设计模式,将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller…

php实现定时

php实现定时

PHP 实现定时任务的方法 PHP 本身是脚本语言,通常需要借助外部工具或框架实现定时任务。以下是几种常见方法: 使用 Cron 任务 Linux 系统自带的 Cron 是常用的定时任务工具。通过编…