[英]PHP redirect back to previous page
我为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']
,但此变量不包含任何内容; 它只包含一些东西,如果你在这里因为你点击了一个链接。
让重定向的页面设置一个会话变量,该变量是该页面的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;
以上可以改进,但这应该给你的想法。
$ _SERVER ['HTTP_REFERER']取决于Web浏览器,并非所有浏览器都将引用者发送回服务器。 许多大型网站使用的更好的方法是将当前页面传递到登录页面:
header("Location: first.php?".$currentPageUrl);
$ current_SUrl可以从$ _SERVER ['REQUEST_URI']或$ _SERVER ['PHP_SELF']获取;
登录后,您可以再次将用户重定向到$ currentPageUrl。
除此之外,将用户名和密码存储在$ _SESSION中听起来并不合适,但这是一个单独的问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.