2015-11-26 85 views
0

我有一个注销按钮,似乎不工作。点击它后,我仍然可以看到“欢迎用户名”,注销按钮仍然存在,如下图所示。请让我知道我的logout.php上缺少什么。注销不起作用

我还可以问我怎样才能在点击注销后将用户重定向到原始页面?我尝试使用"header('Location: ' . $_SERVER['HTTP_REFERER']);"但它不起作用?

enter image description here
的index.php

<?php 
ini_set("session.save_path", "sessionData"); 
session_start(); 
?> 

<?php if (!isset($_SESSION['uName'])) { ?> 
    <form method="post" action="logonProcess.php"> 
    <div>Username <input type="text" name="userName" placeholder="Username"></div> 
    <div>Password <input type="password" name="pwd" placeholder="Password"></div> 
    <div><input type="submit" value="Logon"></div> 
    </form> 
<?php } else { }?> 



<?php if (isset($_SESSION['uName'])) { 
    $username = $_SESSION['uName'];  
    echo "<p>Welcome $username</p>\n"; 
?> 
     <a href="logout.php">Logout</a> 

<?php } else { }?> 

Logout.php

<?php 
unset($_SESSION['user']); 
session_destroy(); // Destroying All Sessions 
header("Location: index.php"); // Redirecting To Home Page 
?> 
+0

查看关于引用链接的手册http://php.net/manual/en/reserved.variables.server.php。它并不总是设置。应该检查并且有一个默认值,如果不是,不是所有的用户代理都会设置它,有些提供修改HTTP_REFERER作为一个功能的能力。总之,它不能真正被信任。“ – chris85

+1

你有没有试过[This one](http://stackoverflow.com/a/3512570/3583859)接受的答案 –

+0

为什么你不设置一个不同于你设置的会话变量? – Barmar

回答

1

尝试添加这对您的注销文件:

unset($_SESSION['uName']); 
2

开始尝试会话时的第一:

Logout.php

<?php 
    session_start(); 
    unset($_SESSION['uName']); 
    session_destroy(); // Destroying All Sessions 
    header("Location: index.php"); // Redirecting To Home Page 
?> 

源来自:http://www.hackingwithphp.com/10/3/5/ending-a-session

+0

获胜者赢家,如果不开始会话,您将无法访问会话甚至取消设置。 – Darren

1

使用会话的所有脚本需要使用相同的session.save_path设置。由于您在index.php中设置了该值,因此还需要将其设置为logout.php。否则,logout.php将无法​​访问会话数据。