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 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥15 关于超局变量获取查询的问题
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集
  • ¥15 在启动roslaunch时出现如下问题
  • ¥15 汇编语言实现加减法计算器的功能
  • ¥20 关于多单片机模块化的一些问题
  • ¥30 seata使用出现报错,其他服务找不到seata