PHP重定向回上一页

时间:2013-07-25 01:07:28

标签: php session redirect http-referer

我为login.php页面所做的是,如果用户已登录,他将被重定向到first.php页面。

session_start();
if(isset($_SESSION['usr']) && isset($_SESSION['pswd'])){
    header("Location: first.php");
} 

在所有其他页面中,如果用户尚未登录,则会将其重定向到login.php页面。

session_start();
if(!isset($_SESSION['usr']) || !isset($_SESSION['pswd'])){
    header("Location: login.php");
} 

问题在于:有没有办法将用户重定向回他所在的位置?如果您在未登录时尝试访问second.php,则会立即将您重定向到login.php页面;一旦你登录,你可以重定向回second.php而不是first.php吗?

我尝试使用$_SERVER['HTTP_REFERER'],但此变量不包含任何内容;如果你在这里,因为你点击了一个链接,它只包含一些东西。

2 个答案:

答案 0 :(得分:6)

  1. 在他们尝试登录的页面上设置包含该页面URL的会话变量。
  2. 然后将它们重定向到登录页面。
  3. 成功登录后,从会话中获取以前的URL并将其重定向到那里。
  4. 让重定向的页面设置一个会话变量,该变量是该页面的URL:

    session_start();
    if (!$logged_in)
    {
        $_SESSION['redirect_url'] = $_SERVER['PHP_SELF']; 
        header('Location: login.php');
        exit;
    }
    

    然后在成功登录后将其重定向到该URL:

    session_start();
    
    /* Login code goes here */
    
    $redirect_url = (isset($_SESSION['redirect_url'])) ? $_SESSION['redirect_url'] : '/';
    unset($_SESSION['redirect_url']);
    header("Location: $redirect_url", true, 303);
    exit;
    

    以上内容可以改进,但这应该会给你一个想法。

答案 1 :(得分:2)

$ _ SERVER ['HTTP_REFERER']取决于Web浏览器,并非所有浏览器都将引用者发送回服务器。许多大型网站使用的更好的方法是将当前页面传递到登录页面:

header("Location: first.php?".$currentPageUrl);

$ currentPageUrl可以从$ _SERVER ['REQUEST_URI']或$ _SERVER ['PHP_SELF']获取;

登录后,您可以再次将用户重定向到$ currentPageUrl。

除此之外,将用户名和密码存储在$ _SESSION中听起来并不合适,但这是一个单独的问题。