值得一看
广告
彩虹云商城
广告

热门广告位

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

答案:该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><?= $error ?></p>
<?php endif; ?>

用户登录(login.php)

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

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

<?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>注册成功,请登录</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><?= $error ?></p>
<?php endif; ?>

用户仪表盘(dashboard.php)

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

百宝箱

百宝箱

百宝箱是支付宝推出的一站式AI原生应用开发平台,无需任何代码基础,只需三步即可完成AI应用的创建与发布。

百宝箱313

查看详情
百宝箱

<?php
session_start();
if (!isset($_SESSION['user_id'])) {
header("Location: login.php");
exit;
}
?>
<p><h2>欢迎,<?= htmlspecialchars($_SESSION['username']) ?>!</h2>
<p>这是你的个人面板。</p>
<a href="https://www.php.cn/faq/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教程 mysql php word html go session sql注入 会话管理 用户注册 lsp red php sql xss if Session Error pdo register input 数据库 https

大家都在看:

PHP数据库权限管理详解_PHPGRANTREVOKE用户授权方法
PHP源码AI算法嵌入_PHP源码AI算法嵌入详解
PHP代码怎么上传文件_ PHP文件上传机制与安全检查步骤
mamp怎么导入php_mamp环境导入php项目方法
怎么运行php网页_php网页运行环境搭建指南
温馨提示: 本文最后更新于2025-09-23 22:29:41,某些文章具有时效性,若有错误或已失效,请在下方留言或联系在线客服
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞12赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容