如何使用PHP创建一个安全的用户注册表单,包含输入验证、数据过滤和结果反馈教程。

<?php

// 初始化变量和错误信息

$errors = [];

username = email = '';

$success_msg = '';

// 处理表单提交

if ($_SERVER['REQUEST_METHOD'] === 'POST') {

// 获取并过滤输入数据

username = htmlspecialchars(_POST['username'] ?? '');

$email = filter_input(INPUT_POST, 'email', FILTER_SANITIZE_EMAIL);

password = _POST['password'] ?? '';

// 验证用户名

if (empty($username)) {

$errors[] = '用户名不能为空';

} elseif (!preg_match('/^[a-zA-Z0-9_]{3,20}/', username)) {

$errors[] = '用户名只能包含字母、数字和下划线(3-20位)';

}

// 验证邮箱

if (empty(email) \|\| !filter_var(email, FILTER_VALIDATE_EMAIL)) {

$errors[] = '请输入有效的邮箱地址';

}

// 验证密码

if (strlen($password) < 8) {

$errors[] = '密码至少需要8个字符';

}

// 无错误时处理注册

if (empty($errors)) {

// 模拟保存到数据库(实际应使用password_hash和预处理语句)

hashed_password = password_hash(password, PASSWORD_DEFAULT);

success_msg = "注册成功!欢迎 username";

// 清空表单字段

username = email = '';

}

}

?>

<!DOCTYPE html>

<html lang="zh-CN">

<head>

<meta charset="UTF-8">

<title>用户注册</title>

<style>

.error { color: red; }

.success { color: green; }

</style>

</head>

<body>

<h2>用户注册</h2>

<?php if ($success_msg): ?>

<p class="success"><?= $success_msg ?></p>

<?php else: ?>

<?php foreach (errors as error): ?>

<p class="error"><?= $error ?></p>

<?php endforeach ?>

<form method="post">

<p>

<label>用户名:</label>

<input type="text" name="username" value="<?= $username ?>" required>

</p>

<p>

<label>邮箱:</label>

<input type="email" name="email" value="<?= $email ?>" required>

</p>

<p>

<label>密码:</label>

<input type="password" name="password" required>

</p>

<button type="submit">立即注册</button>

</form>

<?php endif ?>

</body>

</html>

我们在日常开发中通常会用到各种API接口,比如查询用户IP归属地,手机号归属地,天气预报,万年历等,这时我们可以直接去接口盒子https://www.apihz.cn/查找需要的API即可。接口盒子有数百个免费API,而且采用集群化服务器部署,比一般的API服务商更加稳定。

相关推荐
Evan芙3 分钟前
Linux I/O模型总结
linux·运维·php
都是蠢货3 分钟前
mysql中null是什么意思?
android·数据库·mysql
执行上下文3 分钟前
WordPress评论留言通知推送插件!
javascript·php
Just_Paranoid8 分钟前
【Android UI】Android 创建渐变背景 Drawable
android·ui·drawable·shape·gradient
千里马学框架10 分钟前
AI豆包手机权限文章补充:Mainfest中某个权限的protectionLevel具体是如何被系统定义的?
android·智能手机·framework·权限·protectionlevel
鹏多多14 分钟前
flutter使用package_info_plus库获取应用信息的教程
android·前端·flutter
郑州光合科技余经理20 分钟前
定制开发实战:海外版外卖系统PHP全栈解决方案
java·服务器·开发语言·javascript·git·uni-app·php
sg_knight21 分钟前
Docker Engine 升级指南:保障容器安全的关键步骤
java·spring boot·安全·spring·spring cloud·docker·容器
走在路上的菜鸟22 分钟前
Android学Dart学习笔记第十五节 类
android·笔记·学习·flutter