簡體   English   中英

PHP:頁面未重定向回登錄頁面

[英]PHP: Page not redirected back to the login page

我有一個帶有usernamepassword字段的formlogin.html文件,在submit button它使用mysql database檢查表單中的值。
我的PHP代碼在另一個名為login.php文件中

問題是,當我輸入正確的用戶名和密碼時,它工作正常。 但是,如果我輸入了錯誤的輸入或將它們保留為空,則如果重定向到login.html頁面,它將重定向到login.php頁面。

login.php

<?php

 ### Check if the Submit button is clicked
        if (isset($_POST['btnSubmit']))
         {
            # code...
            //$uname=$_POST['uname'];
            //$pswd=$_POST['pswd']; 

    #### Connection to mySQL ####
    $conn=mysqli_connect("localhost","root","","vishal") or die("Unable to connect to MySQL");



            if (mysqli_connect_errno())
            {
                echo "Failed to connect to MySQL: " . mysqli_connect_error();
            }

            $result = mysqli_query($conn,"SELECT * FROM login where username = '$_POST[uname]' AND password = '$_POST[pswd]'") or die(mysql_error());

            $row = mysqli_fetch_array($result) or die(mysql_error());

                    $username=$row['username'];
                    $password=$row['password'];


                    if (!empty($username) AND !empty($password)) 
                    {   # code...
                        //$_SESSION['username'] =$password;
                        header('location:welcome.html');
                    }

                    else //(empty($username) AND empty($password))
                    {   # code...
                        header('location:login.html');
                        die();
                    }  

}

?>


login.html

<form action="login.php" name="login_form" method="post" enctype="multipart/form-data" target="_self">
    <fieldset style="width:300px; margin:auto; margin-top:100px; border:solid 2px #900; background-color:#CCC; border-radius: 50px">    
        <h1 style="color:#306;"> <center> Login Form </center></h1> <br> <br>
        <div style="margin-left:30px;">

         <table>
         <tr>   
            <td align="right"> <label for="uname"> <strong>Username :</strong> </label> </td>
            <td>        <input type="text" title="Username" id="uname" name="uname" placeholder="Username" />   </td>
          </tr>
          <tr><td>  </td><td> </td> </tr>
          <tr>   
            <td align="right"> <label for="pswd"> <strong>Password :</strong> </label>  </td>
            <td>        <input type="password" title="Password" id="pswd" name="pswd" placeholder="Password" />     </td>
          </tr>
          <tr><td><br /> </td><td> <br /></td>  </tr>
          <tr>
            <td></td>
            <td>        <input type="submit" title="Submit" name="btnSubmit" id="btnSubmit" value="Submit"  style="width:100px; height:26px; font-weight:bold;" />  </td>
            </tr>
           <tr><td><br /> </td><td> <br /></td> </tr>         
        </table>
        </div>
    </fieldset>
</form>

使用此代碼:

$result = mysqli_query($conn,"SELECT * FROM login where username = '$_POST[uname]' AND password = '$_POST[pswd]'") or die(mysql_error());
$row_count = mysql_num_rows($result);
if($row_count==1) {
    $row = mysqli_fetch_array($result) or die(mysql_error());
    $username=$row['username'];
    $password=$row['password'];
     header('location:welcome.html');
} else {
    header('location:login.html');
    die();
}

您必須在login.php這樣做

<?php

 ### Check if the Submit button is clicked
if (isset($_POST['btnSubmit']))
{

    $conn=mysqli_connect("localhost","root","","vishal") or die("Unable to connect to MySQL");
    if (mysqli_connect_errno()){
        echo "Failed to connect to MySQL: " . mysqli_connect_error();
    }

    if(!empty($_POST['uname']) && !empty($_POST['pswd'])) {
        $result = mysqli_query($conn,"SELECT * FROM login where username = '$_POST[uname]' AND password = '$_POST[pswd]'") or die(mysql_error());
        $row_count = mysqli_num_rows($result);
        if($row_count==1) {
           $row = mysqli_fetch_array($result) or die(mysql_error());
           $username=$row['username'];
           $password=$row['password'];
           header('location:welcome.html');
        } else {
           header('location:login.html');
           die();
        }
    } else {
        header('location:login.html');
        die();
    } 
}

?>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM