【发布时间】:2013-09-12 09:06:18
【问题描述】:
编辑:
如果我使用下面的脚本,它会与其他页面产生一些冲突:
if (!isset( $_GET[ "id" ] ) ) {
header( "Location: home.php" );
}
这允许访问者访问所有带有 URL 参数的页面,例如:friends.php?id=22,这是我不想要的。 访问者应该可以访问的唯一带有参数的 URL 是 profile.php?id=$id
正在做一个需要用户注册/登录的小项目。
到目前为止,如果访问者(未登录)输入profile.php,他们将自动被重定向到主页。
现在,我想要完成的是,如果他们特别想查看用户的个人资料,例如 profile.php?id=22,则不要重定向他们。
这是我目前所拥有的:
if ((!preg_match(" {(?:login|logout|signin|register|profile)\.php$}",
$_SERVER["PHP_SELF"])) && (empty($_SESSION["id"])) )
{
header('Location: home.php');
}
不幸的是,这将重定向所有输入 profile.php?id=22 的访问者。
简而言之,
profile.php 应该重定向,profile.php?id=$id 不应该。
【问题讨论】: