如何使用PHP重定向到另一个页面

时间:2011-02-02 07:50:44

标签: php

我正在建立一个包含登录页面的网站。我需要在用户成功登录后将用户重定向到他们的个人资料页面,但我不知道如何在PHP中这样做(这是我的第一个网站)。

我已经搜索了互联网,并且被告知header()函数应该可以解决这个问题,但只有在我使用它之前没有输出任何信息时它才会起作用。

这就是问题所在。我输出了一堆信息(包括HTML来构建登录页面本身)。

那么如何将用户从一个页面重定向到另一个页面?

我有哪些选择?此外,这些情况下的最佳做法是什么?


编辑:这是我的整个login.php页面

<?php 

session_start(); 

echo "<!DOCTYPE html> 
  <html> 
     <head> 
        <meta charset='utf-8'> 
        <title>Sprout</title>
    <link rel='stylesheet' href='stylesheet.css' type='text/css'>
     </head>
 <body>
    <div class='box'>
    <form action='login.php' method='post'>
       Name<br /> <input type='text' name='username' class='form'/><br />
       Password<br /> <input type='password' name='password' class='form'/>
       <input type='submit' value='Login' class='button' />
    </form>
    </div>
 </body>
  </html>";

if ($_SERVER['REQUEST_METHOD'] == 'POST') 
{
    $username = $_POST["username"];
    $password = $_POST["password"];

    $dbhost = "localhost";
    $dbuser = "root";
    $dbpass = "root";

    $conn = mysql_connect($dbhost, $dbuser, $dbpass) or die ("Error connecting to database");

    $dbname = "database";

    mysql_select_db($dbname);

    $query = "SELECT username FROM users WHERE username = '$username' AND password = '$password'";

    $result = mysql_query($query) or die ("Failed Query of " . $query);


    while($row = mysql_fetch_assoc($result))
    {
            $_SESSION["user"] = $username;
    }
}
?>

12 个答案:

答案 0 :(得分:27)

您可以使用类似于以下的功能:

function redirect($url) {
    ob_start();
    header('Location: '.$url);
    ob_end_flush();
    die();
}

值得注意的是,您应该始终在ob_flush()个函数的开头使用ob_start()header('location: ...');,并且应始终使用die()或{{ 1}}用于防止进一步执行代码的函数。

这是比任何其他答案提到的更详细的指南:http://www.exchangecore.com/blog/how-redirect-using-php/

本指南包含在重定向中使用exit() / die()功能的原因,以及何时使用exit() vs ob_flush()以及其他可能出现的错误答案已经遗漏了。

答案 1 :(得分:22)

  

这就是问题所在。我输出了一堆信息(包括HTML来构建登录页面本身)。那么如何将用户从一个页面重定向到另一个页面?

这意味着您的应用程序设计非常糟糕。在业务逻辑运行时,您不应该执行输出。使用模板引擎(如Smarty)或使用output buffering来快速修复它。)

另一个选项(虽然不是很好!)会输出JavaScript来重定向:

<script type="text/javascript">location.href = 'newurl';</script>

答案 2 :(得分:14)

您可以有条件地重定向到php文件中的某个页面....

if (/*Condition to redirect*/){
  //You need to redirect
  header("Location: http://www.yourwebsite.com/user.php"); /* Redirect browser */
  exit();
 }
else{
  // do some
}

答案 3 :(得分:9)

header不适用于所有

使用以下简单代码

<?php
        echo "<script> location.href='new_url'; </script>";
        exit;
?>

答案 4 :(得分:2)

假设您正在使用Cookie进行登录,请在setcookie通话后拨打电话 - 毕竟,您必须在任何输出之前拨打该电话。

无论如何,一般来说,您可以检查脚本开头是否存在表单的提交按钮名称,执行逻辑,然后输出内容:

if(isset($_POST['mySubmit'])) {
    // the form was submitted

    // ...
    // perform your logic

    // redirect if login was successful
    header('Location: /somewhere');
}

// output your stuff here

答案 5 :(得分:2)

您可以在发送任何输出之前使用ob_start();。这将告诉PHP将所有输出保留在缓冲区中,直到脚本执行结束,因此您仍然可以更改标题。

通常我不使用输出缓冲,对于简单的项目,我将所有逻辑保留在脚本的第一部分,然后输出所有HTML

答案 6 :(得分:1)

最简单的方法是,在任何输出之前,您的脚本会在脚本的“顶部”验证表单发布的登录数据。

如果登录有效,您将使用“标题”功能重定向。

即使您使用“ob_start()”,有时也会错过一个导致输出的空白。但是,您将在错误日志中看到一条声明。

<?php
ob_start();
if (FORMPOST) {
    if (POSTED_DATA_VALID) {
        header("Location: https://www.yoursite.com/profile/");
        ob_end_flush();
        exit;
    }
}
/** YOUR LOGINBOX OUTPUT, ERROR MESSAGES ... **/
ob_end_flush();
?>

答案 7 :(得分:0)

虽然不安全,(没有冒犯或任何事情),但只需在设置会话变量

后粘贴标题功能
 while($row = mysql_fetch_assoc($result))
    {
            $_SESSION["user"] = $username;
    }
header('Location: /profile.php');

答案 8 :(得分:0)

点击BUTTON操作

   if(isset($_POST['save_btn']))
    {
        //write some of your code here, if necessary
        echo'<script> window.location="B.php"; </script> ';
     }

答案 9 :(得分:0)

firstly create index.php page and just copy paste below code :-

<form name="frmUser" class="well login-form" id="form" method="post" action="login_check.php" onSubmit="return FormValidation()">
    <legend>
        <icon class="icon-circles"></icon>Restricted Area<icon class="icon-circles-reverse"></icon>
    </legend>
    <div class="control-group">
        <label class="control-label" for="inputPassword">Username</label>
        <div class="controls">
            <div class="input-prepend">
                <span class="add-on"><icon class="icon-user icon-cream"></icon> </span>
                <input class="input" type="text" name="username" id="username" placeholder="Username" />
            </div>
        </div>
    </div>
    <div class="control-group">
        <label class="control-label" for="inputPassword">Password</label>
        <div class="controls">
            <div class="input-prepend">
                <span class="add-on"><icon class="icon-password icon-cream"></icon>
                </span> <input class="input" type="password" name="password" id="password" value="" placeholder="Password" />
            </div>
        </div>
    </div>
    <div class="control-group signin">
        <div class="controls ">
            <input type="submit" class="btn btn-block" value="Submit" />
            <div class="clearfix">
                <span class="icon-forgot"></span><a href="#">forgot password</a>
            </div>
        </div>
    </div>
</form>



/*------------------after that ----------------------*/

create a login_check.php and just copy paste this below code :-

<?php
session_start();
include('conn.php');

<?php
/* Redirect browser */
header("location:index.php");

/* Make sure that code below does not get executed when we redirect. */
exit;
?>


<?php

if(count($_POST)>0)
{   

    $result = mysql_query("SELECT * FROM admin WHERE username='".$_POST["username"]."' and password = '".$_POST["password"]."'");
    $row  = mysql_fetch_array($result);

if(is_array($row)) 
{
    $_SESSION["user_id"] = $row[user_id];
    $_SESSION["username"] = $row[username];

    $session_register["user_id"] = $row[user_id];
    $session_register["username"] = $row[username];
} 
else 
{
   $_SESSION['msg']="Invalid Username or Password";
   header("location:index.php");
}
}

if(isset($_SESSION["user_id"]))
{
    header("Location:dashboard.php");
}

?>




/*-----------------------after that ----------------------*/


create a dashboard.php and copy paste this code in starting of dashboard.php



<?php
session_start();
include('conn.php');
include('check_session.php');
?>




/*-----------------------after that-----------------*/ 



create a check_session.php which check your session and copy paste this code :- 


<?php
    if($_SESSION["user_name"]) 
    {
?>
    Welcome <?php echo $_SESSION["user_name"]; ?>. Click here to <a href="logout.php" tite="Logout">Logout.</a>
<?php
    }
    else
    {
     header("location:index.php");
    }
?>





if you have any query so let me know on my mail id farjicompany@gmail.com

答案 10 :(得分:0)

&#13;
&#13;
----------


<?php
echo '<div style="text-align:center;padding-top:200px;">Go New Page</div>'; 
		$gourl='http://stackoverflow.com';
		echo '<META HTTP-EQUIV="Refresh" Content="2; URL='.$gourl.'">';    
		exit;

?>


----------
&#13;
&#13;
&#13;

答案 11 :(得分:0)

就像您使用echo来打印网页一样。您也可以使用重定向功能。

print("<script type=\"text/javascript\">location.href=\"urlHere\"</script>")