php - 用户信息未发送到 MYSQL 数据库
问题描述
我正在尝试制作:为网站创建帐户页面。问题是没有数据被发送到数据库。
这是我放的:
include 'databaseconnection.php';
if (isset($_POST['submitbutton'])) {
include 'databaseconnection.php';
$first = mysqli_real_escape_string($conn, $_POST['first']);
$last = mysqli_real_escape_string($conn, $_POST['last']);
$password = mysqli_real_escape_string($conn, $_POST['password']);
$email = mysqli_real_escape_string($conn, $_POST['email']);
$username = mysqli_real_escape_string($conn, $_POST['username']);
//error handlers
// check for empty feilds
if (empty($first) || empty($last) || empty($password) || empty($email) || empty($username)) {
header("Location: signupcode.php");
exit();
} else {
if (!preg_match("/ˆ[a-zA-Z]*$/",$first) || !preg_match("/ˆ[a-zA-Z]*$/",$last)) {
header("Location: signupcode.php?signup=empty");
exit();
} else {
//email check
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
header("Location: signupcode.php?error");
exit();
} else {
$sql = "SELECT * FROM users WHERE username='$username'";
$result = mysqli_query($conn, $sql);
$resultcheck = mysqli_num_rows($result);
if ($resultcheck > 0) {
header("Location: signupcode.php?error");
exit();
} else {
$sql = "SELECT * FROM users WHERE email='$email'";
$result = mysqli_query($conn, $sql);
$resultcheck = mysqli_num_rows($result);
if ($resultcheck > 0) {
header("Location: signupcode.php?error");
exit();
} else {
//hashing the Password
$hasedpassword = password_hash($password, PASSWORD_DEFAULT);
$sql = "INSERT INTO users (username, firstname, lastname, password, email)
VALUES ('$username', '$first', '$last', '$hasedpassword', '$email');";
$dbservername= "localhost";
$dbusername= "root";
$dbpassword= "";
$dbname = "landingpage-login";
$conn = mysqli_connect($dbservername, $dbusername, $dbpassword, $dbname);
mysqli_query($conn, $sql);
header("Location: signupcode.php");
exit();
}
}
}
}
}
}
?>
问题是,当我转到 localhost:8080/php 我的管理员时,我的表中没有显示任何内容:数据库中的用户:landingpage-login。每次我检查它,它都是空的,用户名,密码等什么都没有......
解决方案
首先,任何编程语言都不能有多个else
语句。您的代码到达第一个else
并执行该块。
尝试拥有
else if (!preg_match("/ˆ[a-zA-Z]*$/",$first) || !preg_match("/ˆ[a-zA-Z]*$/",$last)){//Code}
推荐阅读
- jquery - 获取内容并将其分配给 div jQuery
- c# - 视图中的异步依赖注入
- angular - ngOnInit() 没有激活 login.html
- python - 如何确定用户是否在 django 上创建了个人资料
- python - 如何按照文件在 Windows 资源管理器中出现的顺序对 glob 搜索结果中的文件进行排序?
- python - 如何检查元组的每个第一个元素是否等于数据框列python中的第二个元素
- python - pip 依赖项可以排除或包含在语义预发布标签中吗?
- python - 使用 qHelpEngine
- python - 为给定 URL 保存函数参数的最佳方法
- assembly - 堆栈帧和返回