php会话目录权限拒绝

时间:2015-03-20 07:19:40

标签: php session directory-permissions

我是php的新手

这是登录页面脚本

<?php include('dbconnect.php');

    $username = mysql_real_escape_string($_POST['username']);
    $password = mysql_real_escape_string($_POST['password']);

    $admins_sql = "SELECT * FROM  administrator WHERE   username = '" .$username. "' AND password = '".md5($password). "' AND status = 'Active'";
    $admin_exe = mysql_query($admins_sql, $con);

    //Setting session variable

    $admin_row=mysql_fetch_array($admin_exe);
    $_SESSION['username'] = $admin_row['username'];
    $_SESSION['type'] = $admin_row['type'];

    IF($_SESSION['type'] == 'Admin') {header("Location:admin");exit(); }
    IF($_SESSION['type'] == 'Main') {header("Location:main");  exit(); }
    IF($_SESSION['type'] == 'Teaching') {header("Location:Teaching"); exit(); }
    IF($_SESSION['type'] == 'Exam Cell') {header("Location:Exam Cell"); exit(); }
    IF($_SESSION['type'] == 'Non-Teaching') {header("Location:Non-Teaching"); exit(); }
    IF($_SESSION['type'] == 'Library') {header("Location:Library"); exit(); }
    IF($_SESSION['type'] == 'Main') {header("Location:office"); exit(); }
    IF($_SESSION['type'] == 'Placement') {header("Location:Placement"); exit(); }
    IF($_SESSION['type'] == 'Systems') {header("Location:CC"); exit(); }
    IF($_SESSION['type'] == 'student') {header("Location:student"); exit(); }

?>

具有上述脚本中重定向所示的文件夹。

我的问题是如果教学类型用户登录,他们将被重定向到显示URL IP地址/主文件夹名称/ Teaching / index.php。他们可以将url中的Teaching更改为admin,然后输入admin文件夹并访问管理员功能。

我想要的是一种类型的用户不要输入其他类型的用户文件夹。

1 个答案:

答案 0 :(得分:0)

例如,在主页面上,您应该验证访问权限,并对您拥有的每个区域执行相同操作。还有其他方法可以做到这一点,但这种方式应该可以满足您的需求。

session_start();
if( !isset( $_SESSION['type'] ) AND $_SESSION['type'] != 'Main' ) {
    header("Location: AccessDenied");
}