dousi4148 2013-10-11 10:29
浏览 95
已采纳

!isset使用有效变量返回FALSE? [重复]

This question already has an answer here:

I'm trying to add a bit more security to my website process so that an external user who tries to bypass the login page will run into an !isset that checks whether the login $_SESSION variables are set and if not, destroys the session and redirects back to the main login page.

My problem is that the !isset function returns a FALSE value and thus destroys the session and redirects, but when I test the variables on that page with print_r they are being recognized and stored.

My code (I've blanked out the variables):

<?php  

 session_start();

 if(!isset($_SESSION['xxx'], $_SESSION['xxx']))
  { echo "Login successfull"; }

  else 

  { session_destroy();
    header("location:main_login.php");
  }

?>

If anyone could explain me what I did wrong (not even necessarily give me the answer on paper, I like to understand and learn since I'm a rookie) that would be amazing. I tried looking around but couldn't really find what I was looking for. Many thanks in advance!

</div>
  • 写回答

2条回答 默认 最新

  • douhe6255 2013-10-11 10:35
    关注
    if(!isset($_SESSION['xxx'], $_SESSION['xxx']))
    

    This is checking if the session is not set, note the ! symbol. So you are echoing Login Successfull when the session variables are not set.

    You should have it like the following:

    if(isset($_SESSION['xxx'], $_SESSION['xxx']))
    { 
        echo "Login successfull"; 
    }
    else 
    { 
        session_destroy();
        header("location:main_login.php");
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置