PHP:If-Statement&形成

时间:2015-05-14 21:32:35

标签: php forms

我的代码是......

<?php
        $username = mysql_real_escape_string($_POST['username']);
        $password = mysql_real_escape_string($_POST['password']);
        $passwordr = mysql_real_escape_string($_POST['passwordr']);
        $email = mysql_real_escape_string($_POST['email']);

        if(empty($username) || empty($password) || empty($passwordr) || empty($email)) {
            echo '<div class="alert alert-danger">Bitte fülle alle Felder aus.</div>';
        }

        elseif(!preg_match('/^[a-zA-Z0-9-_^#]{4,15}$/', $username)) {
            echo '<div class="alert alert-danger">Bitte gebe einen gültigen Usernamen ein.<br />Der Username muss mindestens 4 und maximal 15 Zeichen lang sein und darf nur folgende Sonderzeichen enthalten: -_^#</div>';
        }

        elseif(!preg_match('/^[a-zA-Z0-9-_*^#?!.,;@€]{8,20}$/', $password)) {
            echo '<div class="alert alert-danger">Bitte gebe ein gültiges Passwort ein.<br />Das Passwort muss mindestens 8 und maximal 20 Zeichen lang sein und darf nur folgende Sonderzeichen enthalten: -_*^#?!.,;@€</div>';
        }

        elseif($passwordr != $password) {
            echo '<div class="alert alert-danger">Die Passwörter stimmen nicht überein.</div>';
        }

        elseif(!preg_match('/^[a-zA-Z0-9-_.]+@[a-zA-Z0-9-_.]+\.[a-zA-Z]{2,4}$/', $email)) {
            echo '<div class="alert alert-danger">Bitte gebe eine gültige E-Mail Adresse ein.</div>';
        }

        else {
            die("have a n1 day");
        }
    ?>

不知何故,即使表格不为空,我总是得到<div class="alert alert-danger">Bitte fülle alle Felder aus.</div>

为什么?

这是我的表格......

<div class="row">
        <form method="POST">
            <fieldset>
                <div class="col-lg-5">
                    <div id="username-group" class="form-group">
                        <label for="username">Username</label>
                        <input type="text" name="username" id="username" class="form-control" placeholder="Username">
                    </div>
                    <div id="password-group" class="form-group">
                        <label for="password">Passwort</label>
                        <input type="password" name="password" id="password" class="form-control" placeholder="Passwort">
                    </div>
                    <div id="passwordr-group" class="form-group">
                        <label for="passwordr">Passwort wiederholen</label>
                        <input type="password" name="passwordr" id="passwordr" class="form-control" placeholder="Passwort wiederholen">
                    </div>
                    <div id="email-group" class="form-group">
                        <label for="email">E-Mail</label>
                        <input type="email" name="email" id="email" class="form-control" placeholder="E-Mail">
                    </div>
                    <input type="submit" name="submit" id="submit" class="btn btn-default" value="Registrieren">
                </div>
            </fieldset>
        </form>
    </div>

我正在使用bootstrap,但我不认为这是问题所在。 并且代码看起来也很好。

1 个答案:

答案 0 :(得分:0)

如果添加错误记录

error_reporting(E_ALL);
ini_set('display_errors','On');
你会看到这个:

  

不推荐使用:mysql_real_escape_string() :mysql扩展名为   已弃用并将在以后删除:使用mysqli或PDO   而是在 ... / public_html / index.php 38

     

警告:mysql_real_escape_string() :拒绝访问用户'www-data'@'localhost'(使用密码:否)   第38行上的 ... / public_html / index.php

mysql_real_escape_string要求您先连接到数据库。事实上,这个功能也已被弃用。

您可以从代码中删除mysql_real_escape_string,看它是否有效。