PHP、MySQL 验证故障和搜索不起作用?

Posted

技术标签:

【中文标题】PHP、MySQL 验证故障和搜索不起作用?【英文标题】:PHP, MySQL validation malfunction and search doesn't work? 【发布时间】:2012-07-02 20:52:19 【问题描述】:

我创建了一个小的注册粘滞表格。一切正常,但是如果我输入了任何错误的值,例如姓名中的数字、年龄中的字母甚至错误的电子邮件格式,那么数据仍然保存在数据库中,我无法弄清楚验证问题。 另一个 1 是搜索选项。每当我在搜索框中输入任何名字或姓氏时,它都应显示数据库中的名称,否则将显示错误消息。 任何 1 都可以建议我该怎么做。请在下面查看我的编码。

sticky_form 代码...

<html>
<head>


<?php
global $fname,$lname,$gender,$age,$course,$email;

if(isset($_POST['register']))


    $fname=$_POST['fname'];
    $lname=$_POST['lname'];
    $gender=$_POST['gender'];
    $age=$_POST['age'];
    $course=$_POST['course'];
    $email=$_POST['email']; 

        if (preg_match("/[a-zA-Z ]+$/", $_POST['fname']))  
            $fname = trim($_POST['fname']);
        
         else 
        
        echo '<p>The First name is empty or has illegal characters! To edit please go the link Display Data Information</p>';
        //$error = true;
        


        if (preg_match("/[a-zA-Z ]+$/", $_POST['lname']))  
            $lname = trim($_POST['lname']);
        
         else 
        
        echo '<p>The last name is empty or has illegal characters! To edit please go the link Display Data Information</p>';
        $error = true;
        

        if(isset($_POST['gender']))
           
            $gender = $_POST['gender']; 
        
        else
        
            echo "<p>No gender found!</p>";
        

        if (preg_match("/[a-zA-Z ]+$/", $_POST['age']))  
            $age = trim($_POST['age']);
        
         else 
        
        echo '<p>Please enter age. Or your age contains illegal characters</p>';
        //$error = true;
        

        if(isset($_POST['course']))
        
             $course = $_POST['course'];
        
        else
        
            echo "<p>Please Select Course!</p>";

        

        // Validate the email:
        if (preg_match("/^[\w.-]+@[\w.-]+\.[A-Za-z]2,6$/", $_POST['email'] ))
        $email = trim($_POST['email']);
        
        else 
        
        echo '<p>The email is empty or has illegal characters! To edit please go the link Display Data Information</p>';
        //$error = false;
        
        echo "<br/>";
        echo "<br/>";
        echo "<br/>";





    if($fname&&$lname&&$gender&&$age&&$email&&$course)
    
    require_once('connection.php');
    $query = mysql_query("INSERT INTO members SET FirstName='$fname', LastName='$lname', Gender='$gender', Age='$age',          Email='$email', Course='$course'") or die(mysql_error());

        if($query)
            echo"Your Data Successfully Saved"; 
        
        else
        
            echo "Please recheck your Data!";
        





?>
</head>

<body id="body">
<h2><strong>Register Student Account</strong></h2>
<form action="student_form.php" method="post" >
<table border="1" id="container">


  <tr>
    <td>First Name</td>
    <td>:</td>
    <td><input type="text" name="fname"  size="30" maxlength="50"/></td>
  </tr>

 <tr>
    <td>Last Name</td>
    <td>:</td>
    <td><input type="text" name="lname" size="30" maxlength="50"/></td>
  </tr>

  <tr>
    <td>Age</td>
    <td>:</td>
    <td><input type="text" name="age"  size="3" /></td>
  </tr>

    <tr>
    <td >Gender </td>
    <td> : </td>
    <td> Male
    <input type="radio" name="gender" value="Male"/>

    Female
    <input type="radio" name="gender" value="Female"/></td>

  </tr>


  <tr>
    <td valign="top">Course</td>
    <td valign="top"> : </td>
    <td> <input type="radio" name="course" value="Bachelor Of Computing"/>Bachelor Of Computing<br/>
   <input type="radio" name="course" value="Bachelor Of Science"/>Bachelor Of Science<br/> 
   <input type="radio" name="course" value="Bachelor Of Software Engineering"/>Bachelor Of Software Engineering<br/>
    <input type="radio" name="course" value="Bachelor Of Networking"/>Bachelor Of Networking<br/>
    <input type="radio" name="course" value="Bacelor Of IT"/>Bacelor Of IT <br/>
    <input type="radio" name="course" value="Bachelor Of Computer Science"/>Bachelor Of Computer Science<br/></td>

  </tr>

 <tr>
    <td>Email Address</td>
    <td>:</td>
    <td><input type="text" name="email"  size="30" maxlength="50"/></td>
</tr>


</table>
    <input type="submit" name="register" value="REGISTER"/>

</form><br>
<p><a href="student_form.php" >Home</a></p>
<p><a href="display_data.php">Display Data Information</a>
<p><a href="search.php">To search for Members</a>
</body>
</html>

这是search_form代码......

<html>
<head>
<?php
//require_once('student_form.php');
if(isset($_POST['s1'])) 
$id=$_REQUEST['id']; 
$fname=$_POST['fname'];
    //connect  to the database 
include('connection.php');
//-query  the database table 
$sql=mysql_query("SELECT  * FROM members WHERE (FirstName LIKE '". $fname ."%' OR LastName LIKE '". $lname ."%'");
    //-run  the query against the mysql query function 
    $result=mysql_query($sql); 

    if($row=mysql_fetch_array($result)) 
                $fname=$row['FirstName']; 
                $lname=$row['LastName']; 
                /*$email=$row['Email'];
                $age =$row['Age'];
                $gender=$row['Gender'];
                $course = $row['Course'];*/
    
    //-display  the result of the array 
    else
    
    <?php echo $rows['FirstName']; ?>
    <?php echo $rows['LastName']; ?>
     
 
?>
</head>
<body>
<form action="search.php" method="post">
<table>
    <tr>
    <td><strong>search box</strong></td>
    <td><strong>:</strong></td>
    <td><input type="text" name="search" value=""size="30"/><input type="submit" name="s1" value="Search"/></td>

</table>
</form>
</body>
</html>

【问题讨论】:

【参考方案1】:

$fname $lname $gender $age $email $course 之类的变量在isset($_POST['register']) 的 if 条件之后放入 if 条件。现在,即使您的验证有效,数据仍将输入数据库。因为你设置了条件

if($fname&amp;&amp;$lname&amp;&amp;$gender&amp;&amp;$age&amp;&amp;$email&amp;&amp;$course)

现在,当您在所有这些变量中只有一个值时,控制就会进入该块。必须发生的是,您输入了错误的值,这些值正在得到验证,将显示消息,但是当第一个 if 块完成时,因为 $_POST 变量仍然有一些值,无论它们是否无效,第二个 if 块将被输入并且查询将被触发。

您可以做的是,无论您在何处回显错误消息,都将相应的变量置空。像这样:

if (preg_match("/[a-zA-Z ]+$/", $_POST['fname']))  
    $fname = trim($_POST['fname']);

else 

    echo '<p>The First name is empty or has illegal characters! To edit please go the link Display Data Information</p>';
    $fname = "";

【讨论】:

哇哇哇!它工作..非常感谢...我真的很感激..但是你能帮我多做一件事吗?我有一个搜索页面,上面给出了代码,例如:用户输入姓名或姓氏或电子邮件,然后按搜索,这会将数据库中所需成员的结果显示到页面。 你的sql查询好像有错误...WHERE子句后面有个括号,不需要,去掉试试【参考方案2】:

至于你的第一个问题,不要查$var,查!empty($var)

第二个问题:我不确定我是否理解您要做什么。但是,当您显示某些内容时,您不是说$row 而不是$rows 吗?另外,如果您有多个搜索结果怎么办?你想要的是:

while($row=mysql_fetch_assoc($result))
   echo $row['Firstname'], ' ', $row['LastName'];

而不是你的 if-else 构造。

【讨论】:

以上是关于PHP、MySQL 验证故障和搜索不起作用?的主要内容,如果未能解决你的问题,请参考以下文章

OR运算符在mysql php中不起作用[重复]

逗号分隔值在 PHP MYSQL 中不起作用 [重复]

使用 PDO 连接 Mysql 数据库不起作用

react-bootstrap:模态的 dialogClassName 道具不起作用

phonegap:基于 cookie 的身份验证 (PHP) 不起作用 [webview]

php搜索功能不起作用