这篇文章将为大家详细讲解有关php清除所有session的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
php清除所有session的方法:首先注销所有的Session变量;然后使用session_destroy()函数结束当前的会话,并清空所有的资源,彻底销毁Session即可。
彻底销毁session
如果整个 Session 会话已经结束,首先应该注销所有 Session 变量,然后使用 session_destroy() 函数清除结束当前的会话,并清空会话中的所有资源,彻底销毁Session,其代码如下显示:
<?php session_destroy(); ?>
session_start() 函数用来创建 Session 文件,而 session_destroy() 函数用来关闭 Session 的运作并删除 Session 文件,成功则返回 TURE,失败则返回 FALSE。但该函数并不会释放和当前 Session 相关的变量,也不会删除保存在客户端 Cookie 中的 Session ID 。
php中默认的 Session 是基于 Cookie 的,Session ID 被服务器存储在用户浏览器的 Cookie 中,所以在注销 Session 时也需要清除 Cookie 中保存的 Session ID,而这就必须借助 setcookie() 函数来完成。
在用户浏览器的 Cookie 中,保存 Session ID 的 Cookie 标识名称就是 Session 的名称,这个名称是在 php.ini 中,通过 session.name 属性指定的值。在php脚本中,可以通过 session_name() 函数获取 Session 的名称。 删除保存在客户端 Cookie 中的 Session ID。
完整代码如下:
<?php //开启 Session session_start(); // 删除所有 Session 变量 $_SESSION = array(); //判断 cookie 中是否保存 Session ID if(isset($_COOKIE[session_name()])) { setcookie(session_name(),'',time()-3600, '/'); } //彻底销毁 Session session_destroy(); ?>
关于php清除所有session的方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。