php - 如果验证没有失败则提交数据(PHP、MYSQL)

标签 php mysql forms submit registration

所以我正在编写一个注册脚本,但我还没有弄清楚如何实现在表单输入无效时阻止数据提交。

我有一个姓名字段、电子邮件字段和密码字段。这三者都有自己的验证。代码如下所示:

    <form action="config.php" method="post">
    Benutzername:<br>
    <input type="Text" autofocus name="username" value="<?php if(!empty($_POST["username"])) echo $name; ?>">
    <span class="req"><?php echo $nameErr;?></span><br><br>
    Email:<br>
    <input type="text" name="email" value="<?php if(!empty($_POST["email"])) echo $_POST['email']; ?>">
    <span class="req"><?php echo $emailErr;?></span><br><br>
    Passwort:<br>
    <input type="password" name="password" value="">
    <span class="req"><?php echo $passErr;?></span><br><br>
    <input type="Submit" name="send" value="Absenden">
</form>

验证发生在上面:

    if ($_SERVER["REQUEST_METHOD"] == "POST") {
    if (empty($_POST["username"])) {
        $nameErr = "Dieses Feld darf nicht leer bleiben.";
        $name = "";
    } else {
        $nameCheck = false;
        $nameErr = "";
    }

    if (empty($_POST["email"]) || !filter_var($_POST['email'], FILTER_VALIDATE_EMAIL)) {
            $emailErr = "Bitte eine gültige Email-Adresse angeben.";
        $email = "";
    } else {
        $emailCheck = false;
        $email = $_POST['email'];
        $emailErr = "";

    }

    if (empty($_POST["password"])) {
        $passErr = "Bitte geben Sie ein Passwort an.";
        if(!preg_match('~^(?=.*\d.*\d)[0-9A-Za-z!@#$%*]{6,}$~', $_POST['password'])) {
            $passErr = "Das Passwort muss mindestens zwei Ziffern enthalten und aus 6 Zeichen bestehen.";
        }
    } else {
        $passwordCheck = false;
        $password = $_POST['password'];
        $passErr = "";
    }

}

if($emailCheck != true && $passwordCheck != true && $nameCheck != true) {
    header('Location: index.php');
}

因此,如果一切正确完成,表单应重定向到 config.php。

但是使用这段代码,我可以将所有标签留空,并且无论如何都会提交...

此外,我还检查了 config.php,在数据库中查找电子邮件或用户是否已注册。如何在我的表单页面 (index.php) 上实现此检查?

提前致谢!我希望我在这里所做的一切都是正确的..

最佳答案

<?php 


 if (isset($_POST['send'])) {

        if (empty($_POST["username"])) {
            $nameErr = "Dieses Feld darf nicht leer bleiben.";
            $name = "";
        } else {
            $nameCheck = false;
            $username =$_POST['username'];
            $nameErr = "";
        }

        if (empty($_POST["email"]) || !filter_var($_POST['email'], FILTER_VALIDATE_EMAIL)) {
                $emailErr = "Bitte eine gültige Email-Adresse angeben.";
            $email = "";
        } else {
            $emailCheck = false;
            $email = $_POST['email'];
            $emailErr = "";

        }

        if (empty($_POST["password"])) {
            $passErr = "Bitte geben Sie ein Passwort an.";
            if(!preg_match('~^(?=.*\d.*\d)[0-9A-Za-z!@#$%*]{6,}$~', $_POST['password'])) {
                $passErr = "Das Passwort muss mindestens zwei Ziffern enthalten und aus 6 Zeichen bestehen.";
            }
        } else {
            $passwordCheck = false;
            $password = $_POST['password'];
            $passErr = "";
        }

}
?>

关于php - 如果验证没有失败则提交数据(PHP、MYSQL),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26926232/

相关文章:

php - 如果 'date` 是 'today' ,触发从数据库中删除行的最佳方式?

php - 如果数据库中没有结果,则显示 "result not found"

javascript - 将表单输入写入全局变量的更好方法?

php - 从数据库获取类别期间按类别过滤器计算行数

php - 目前我得到了我的查询结果,但我想获得记录数

javascript - 如何在 handleSubmit 中从 react-query 实现 useMutation

php - 尝试获取登录错误消息/验证以在登录表单上工作?

php - 错误未在PHP中显示

php - 使用 JQuery ajax.Post() 更新数据库

mysql - 删除查询正在运行并且不删除任何数据