我为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']
,但此变量不包含任何内容;如果你在这里,因为你点击了一个链接,它只包含一些东西。
答案 0 :(得分:6)
让重定向的页面设置一个会话变量,该变量是该页面的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中听起来并不合适,但这是一个单独的问题。