2015-05-14 42 views
0

我的代碼是...PHP:if語句和表單

<?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-_.][email protected][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> 

我使用的引導,但我不認爲這是問題。 而且代碼看起來也不錯。

它看起來像你的文章主要是代碼;請添加更多的細節。

+3

您的變量在哪裏設置?你能否提供你的表單標記? –

+0

首先檢查你是否從表單中取回值,你可以使用:print_r($ _ REQUEST); die; 。比顯示更多的代碼實際上將$ _POST(或$ _GET)賦值給這些變量。你沒有使用摘錄,對吧? – Mahakala

+1

您意識到該名稱不會奇蹟般地變成'$ username',而是'$ _POST ['username']' – adeneo

回答

0

如果添加了錯誤日誌

error_reporting(E_ALL); 
ini_set('display_errors','On'); 

,你會看到:

推薦使用:mysql_real_escape_string():MySQL擴展是 過時,並將在將來被移除:使用的mysqli或PDO 而不是.../public_html/index.php on line

警告:mysql_real_escape_string()拒絕訪問用戶 'www數據' @ 'localhost' 的(使用密碼:NO)在 ... /的public_html/index.php文件線38

mysql_real_escape_string要求您先連接到數據庫。這個功能的確也被棄用了。

您可以從代碼開始刪除mysql_real_escape_string以查看它是否有效。