用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php中session_unset与session_destroy的用法与区别

时间:2015-01-23  来源:西部数据  作者:西部数据

本文章来介绍了关于session_unset与session_destroy函数他们之间的区别以及在删除变量时的一些不同的地方法.

session_unset()

释放当前在内存中已经创建的所有$_SESSION变量,但不删除session文件以及不释放对应的session id,代码如下:

  1. <?php 
  2.     session_start(); 
  3.     session_unset(); 
  4.     session_destroy(); 
  5.     session_write_close(); 
  6.     setcookie(session_name(),'',0,'/'); 
  7.     session_regenerate_id(true); 
  8. ?> 

session_destroy()

删除当前用户对应的session文件以及释放session id,内存中的$_SESSION变量内容依然保留,因此,释放用户的session所有资源,需要顺序执行如下代码:

  1. <?php 
  2. $_SESSION['user'] = ‘user1′; 
  3. session_unset(); 
  4. session_destroy(); 
  5. ?> 

删除session方法:

1、unset ($_SESSION['xxx']) 删除单个session,unset($_SESSION['xxx']) 用来unregister一个已注册的session变量。其作用和session_unregister()相同。session_unregister()在PHP5中不再使用,可将之打入冷宫。

unset($_SESSION) 此函数千万不可使用,它会将全局变量$_SESSION销毁,而且还没有可行的办法将其恢复。用户也不再可以注册$_session变量。

2、$_SESSION=array() 删除多个session

3、session_destroy()结束当前的会话,并清空会话中的所有资源,该函数不会unset(释放)和当前session相关的全局变量(globalvariables),也不会删除客户端的session cookie.PHP默认的session是基于cookie的,如果要删除cookie的话,必须借助setcookie()函数.

区别总结:

session_destroy是注销所有的session变量,并且结束session会话; 

session_unset()并不注销session变量,但把所有的session变量的值清空.<

来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门