【发布时间】:2018-07-29 07:34:31
【问题描述】:
我在我正在构建的网站的php 代码中遇到了一个奇怪的问题:
我使用超全局 $_SESSION['recent'] 在我的网页上创建警报。例如,如果用户尝试登录,但输入了错误的密码,登录表单会将其数据发送到文件login.php,该文件会检查所有数据是否正确。如果数据正确,它将设置$_SESSION['recent'] = 'login_succes'(以及其他一些内容,以便用户登录),否则它将设置$_SESSION['recent'] = 'login_fail'。接下来会以header('location: http://www.example.com/')返回首页。
在这个主页中,有一段php 代码带有switch 语句,它检查所有可能的$_SESSION['recent'] 值并根据其值发出警报。这段代码有点像这样(我用的是bootstrap):
<?php switch ($_SESSION['recent']) { ?>
<?php case 'logout': ?>
<div class="container-fluid alert-fixed"><div class="alert alert-success alert-dismissible">
<button type="button" class="btn close" data-dismiss="alert">×</button>
You are signed out.
</div></div>
<?php break; case 'login_succes': ?>
<div class="container-fluid alert-fixed"><div class="alert alert-success alert-dismissible">
<button type="button" class="close" data-dismiss="alert">×</button>
You are signed in
</div></div>
<?php break; case 'login_fail': ?>
... (similar alert message)
<?php break; case 'not_loggedin': ?>
...
<?php break; case 'admin_change_succes': ?>
...
<?php break; case 'admin_change_fail': ?>
...
<?php break; } $_SESSION['recent'] = null; ?>
所以我期望它会检查任何通知并在必要时显示警报消息。完成后,它会设置$_SESSION['recent'] = null,这样这条消息就不会一直显示。
然而,这是问题所在:这适用于前 3 个案例(logout、login_succes 和 login_fail),但对于所有其他案例,警报不会显示,除非我删除 $_SESSION['recent'] = null; 行(我显然不想删除,因为这样警报消息将在重新加载时继续显示)。
有谁知道是什么原因造成的以及如何解决这个问题?如果您需要更多信息,请直接询问。
谢谢!
【问题讨论】:
-
这个文件的 PHP 文件开头是否有
session_start();?此外,您可以取消设置变量unset($_SESSION['recent']),而不是 $_SESSION['recent'] = null。 -
是的,它确实有 session_start() 并且使用 unset() 也不起作用......
-
在 switch 语句之前回显
$_SESSION['recent']并确保它具有您正在寻找的值。确保这些值与您的大小写值匹配。 -
我已经这样做了,正如我在问题中提到的那样:当我删除包含
$_SESSION['recent'] = null;的行时,警报工作得很好 -
@wohe1 我认为您的代码没有问题,它应该可以按预期工作,但现在取决于程序控制如何到达此文件。
标签: php switch-statement session-variables