login.php
验证帐号密码就不发了,发设置session的代码给大家看
session_start();
$_SESSION["userid"]=$rs[ID'];
$_SESSION["useracc"]=$rs[Acc'];
$_SESSION["username"]=$rs[Name'];
$_SESSION["usertype"]="user";
ob_start(); 
header("location:index.php");
ob_end_flush() index.php
if($_SESSION['userid']!=''){    
echo "登录成功";    
echo "<a href='logout.php'>退出</a>";
}else{    
echo "登录失败";
}logout.php
//第一种写法 
session_start(); 
$_SESSION=array();//把$_SESSION 数组清空 
setcookie(session_name(),"",time()-1); //把 cookie 清空 
session_destroy(); //删除本次 SESSION //第二种写法
session_start();
unset($_SESSION['userid']);  
unset($_SESSION['useracc']);   
unset($_SESSION['username']);  
unset($_SESSION['usertype']);  
session_destroy(); //最后都执行
ob_start();
header("location:index.php");
ob_end_flush();
但是不知道为什么,执行logout.php之后(两种写法都试过)返回到index.php的时候还是登录成功,那个$_SESSION里面的数据都还是存在。但是我中断logout.php跳转在前面打出$_SESSION里面是没有值了。 请高手指导一下到底是什么问题!phpsession 无法删除phpsession无法删除

解决方案 »

  1.   

    返回到index.php,是通过浏览器后退按钮吗?
    那没有重新加载页面当然是不会变的
      

  2.   

    不是啊,就是使用的那个header那个里面的重定向跳转的,
    在我本机是可以的,在服务器上就不行了
    本机使用的是apache服务器上是iis
      

  3.   

    你一定有什么地方弄错了!
    测试代码:
    index.php<?php
    session_start();
    if(isset($_SESSION['userid']) && $_SESSION['userid'] != ''){    
      echo "已经登录 <a href='logout.php'>退出</a>";
    }else{    
      echo "没有登录 <a href='login.php'>登录</a>";
    }
    login.php
    <?php
    session_start();
    $_SESSION["userid"] = 1;
    ob_start(); 
    header("location:index.php");
    ob_end_flush();logout.php<?php
    session_start(); 
    session_destroy(); //删除本次 SESSION 
    ob_start();
    header("location:index.php");
    ob_end_flush();
      

  4.   


    现在好像session_destory();这个方法在IIS里面无效了
    我先$_SESSION = array();
    然后在session_destory();
    发现前面$_SESSION里面的数据都又回来了,所以导致一致是登录状态,
    后面把session_destory();
    给去掉了
    不知道这样会出现什么样的错误或者是影响。
    希望版主解救
      

  5.   

    把session数组清空的语句都使用了的
    unset($_SESSION['userid']);这种
    session_unset();这种
    $_SESSION = array();这种
    不管是哪一种,只要后面写上了session_destory()
    里面的数据都又全部回来了。