标签: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’],但此变量不包含任何内容;它只包含一些东西,如果你在这里因为你点击了一个链接.
解决方法:
>在他们尝试登录的页面上设置包含该页面URL的会话变量.
>然后将它们重定向到登录页面.
>成功登录后,从其会话中获取以前的URL并将其重定向到那里.
让重定向的页面设置一个会话变量,该变量是该页面的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;
以上可以改进,但这应该给你的想法.
标签:php,session,redirect,http-referer 来源: https://codeday.me/bug/20190725/1533702.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。