php登录怎么写_php用户登录系统完整实现代码

看不見的法師
发布: 2025-09-23 22:17:01
原创
688人浏览过
答案:该PHP登录系统包含注册、登录、会话管理和登出功能,使用PDO预处理语句防SQL注入,password_hash安全存储密码,htmlspecialchars防御XSS,通过session控制用户访问,结构清晰且具备基础安全措施。

php登录怎么写_php用户登录系统完整实现代码

实现一个基础但完整的 PHP 用户登录系统,需要包含用户注册、登录、会话管理以及登出功能。下面是一个简单、安全且可运行的示例,适合初学者理解核心流程。

数据库准备

创建一张用户表用于存储用户名和加密后的密码:

CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50) UNIQUE NOT NULL,
    password VARCHAR(255) NOT NULL
);
登录后复制

数据库连接配置(config.php

统一管理数据库连接:

<?php
$host = 'localhost';
$db   = 'your_database_name';
$user = 'your_db_user';
$pass = 'your_db_password';
<p>try {
$pdo = new PDO("mysql:host=$host;dbname=$db;charset=utf8", $user, $pass);
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
die("数据库连接失败: " . $e->getMessage());
}
?></p>
登录后复制

用户注册(register.php)

接收注册信息,验证并安全存储密码:

<?php
require 'config.php';
<p>if ($_SERVER['REQUEST_METHOD'] == 'POST') {
$username = trim($_POST['username']);
$password = $_POST['password'];</p><pre class='brush:php;toolbar:false;'>if (empty($username) || empty($password)) {
    $error = "请填写所有字段";
} elseif (strlen($password) < 6) {
    $error = "密码至少6位";
} else {
    $stmt = $pdo->prepare("SELECT id FROM users WHERE username = ?");
    $stmt->execute([$username]);

    if ($stmt->rowCount() > 0) {
        $error = "用户名已存在";
    } else {
        $hashed = password_hash($password, PASSWORD_DEFAULT);
        $stmt = $pdo->prepare("INSERT INTO users (username, password) VALUES (?, ?)");
        $stmt->execute([$username, $hashed]);
        header("Location: login.php?registered=1");
        exit;
    }
}
登录后复制

} ?>

<form method="post"> <input type="text" name="username" placeholder="用户名" required><br> <input type="password" name="password" placeholder="密码" required><br> <button type="submit">注册</button> </form> <?php if (isset($error)): ?> <p style="color:red;"><?= $error ?></p> <?php endif; ?>

用户登录(login.php)

验证用户凭据并启动会话:

立即学习PHP免费学习笔记(深入)”;

AISEO
AISEO

AI创作对SEO友好的文案和文章

AISEO 56
查看详情 AISEO

<?php
session_start();
require 'config.php';
<p>if ($_SERVER['REQUEST_METHOD'] == 'POST') {
$username = trim($_POST['username']);
$password = $_POST['password'];</p><pre class='brush:php;toolbar:false;'>$stmt = $pdo->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'];
    $_SESSION['username'] = $username;
    header("Location: dashboard.php");
    exit;
} else {
    $error = "用户名或密码错误";
}
登录后复制

} ?>

<h2>登录</h2> <?php if (isset($_GET['registered'])): ?> <p style="color:green;">注册成功,请登录</p> <?php endif; ?>

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

<?php if (isset($error)): ?> <p style="color:red;"><?= $error ?></p> <?php endif; ?>

用户仪表盘(dashboard.php)

受保护页面,仅登录用户可访问:

<?php
session_start();
if (!isset($_SESSION['user_id'])) {
    header("Location: login.php");
    exit;
}
?>
<p><h2>欢迎,<?= htmlspecialchars($_SESSION['username']) ?>!</h2>
<p>这是你的个人面板。</p>
<a href="logout.php">登出</a></p>
登录后复制

用户登出(logout.php)

销毁会话并返回登录页:

<?php
session_start();
session_destroy();
header("Location: login.php");
exit;
?>
登录后复制

安全提示:

  • 使用 password_hash()password_verify() 处理密码
  • 所有输出使用 htmlspecialchars() 防止 XSS
  • 使用预处理语句防止 SQL 注入
  • 登录页建议启用 HTTPS

基本上就这些。这个登录系统涵盖了核心功能,结构清晰,适合学习和小项目使用。不复杂但容易忽略的是会话安全和输入验证。

以上就是php登录怎么写_php用户登录系统完整实现代码的详细内容,更多请关注php中文网其它相关文章!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号