PHP/MySQL 在数据库中创建空白记录

标签 php html mysql

我有一个用户输入表单 (HTML),它应该获取信息并通过 PHP 将其插入 MySQL 数据库。 PHP 显然执行并回显“您的注册已成功完成”。在数据库中创建了一条记录,但列为空白(我已从 PHP 代码中删除了我的服务器、数据库和密码)。

HTML:

<!DOCTYPE html>

<head>

<link rel="stylesheet" type="text/css" href="css/styles.css">
<title>User Portal</title>

</head>

    <div class="inputContainer">

        <header>
            User Information Portal
        </header>

            <form action="php/userPost.php" method="post">

                <label for=firstName">First Name</label>
                <input type="text" id=firstName" name="fname">

                <br><br>

                <label for="lastName">Last Name</label>
                <input type="text" id="lastName" name="lname">

                <br><br>

                <label for="eMail">Email</label>
                <input type="text" id="eMail" name="email">

                <br><br>

                <label class="labelRole" for="userRole">Role -</label><br>
                <input type="radio" id="userRole" name="role" value="Instructor"> Instructor

                <input class="submitButton" type="submit" name="submit" value="Register">

            </form>

    </div>
    </body>

PHP:

<?php

$sname = "server-name";
$uname = "username";
$pword = "password";
$dbname = "web_tech_test";
$conn = new mysqli($sname, $uname, $pword, $dbname);



if ($conn->connect_error) {
    die("Connection failure: " . $conn->connect_error);
}

$fname = !empty($_POST['firstName']);
$lname = !empty($_POST['lastName']);
$email = !empty($_POST['eMail']);
$role = isset($_POST['userRole']);


$sql = "INSERT INTO users (first_name, last_name, email, role)
VALUES ('$fname', '$lname', '$email', '$role')";

if ($conn->query($sql) === TRUE) {
    echo "Your registration has completed successfully";
} else {
    echo "Error: " . $sql . "<br>" . $conn->error;
}

$conn->close();

?>

这会在数据库中创建一条新记录,但所有列都是空白的。知道为什么会发生这种情况吗?

最佳答案

$fname = !empty($_POST['firstName']);
$lname = !empty($_POST['lastName']);
$email = !empty($_POST['eMail']);
$role = isset($_POST['userRole']);

此代码返回一个 bool 值,而不是一个字符串值...

仅使用 !empty() 进行验证

示例

if(empty($_POST['eMail'])) {
     die("Email cannot be empty");
}

关于PHP/MySQL 在数据库中创建空白记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39336546/

相关文章:

html - 无序列表制作悬停背景而不是悬停链接(文本)

html - 如何找到具有全范围字体粗细的网络字体?

javascript - localscroll.js - 似乎无法弄清楚如何设置链接

php - 图书网站条码扫描仪

php - 当我更改具有相同名称的图像时如何更新 slider 中的图像

php - MS SQL 2005 自动递增错误

php - Eloquent:在模型和他的 parent 身上 Hook 到 'saving' 事件

php - 如何使用其他表中的外键删除具有主键的行?

mysql - where_in 和 find_in_set 之间的区别

php - 由于构造函数,Yii 模型 isNewRecord false