php中session及cookie常用操作

session操作

session:Session是指一个终端用户与交互系统进行通信的时间间隔,通常指从注册进入系统到注销退出系统之间所经过的时间以及如果需要的话,可能还有一定的操作空间。

session的工作原理
(1)当一个session第一次被启用时,一个唯一的标识被存储于本地的cookie中。
(2)首先使用session_start()函数,PHP从session仓库中加载已经存储的session变量。
(3)当执行PHP脚本时,通过使用session_register()函数注册session变量。
(4)当PHP脚本执行结束时,未被销毁的session变量会被自动保存在本地一定路径下的session库中,这个路径可以通过php.ini文件中的session.save_path指定,下次浏览网页时可以加载使用。
 

设置session
sessin_start();
$_SESSION['haha'] = null;
uset($_SESSION['haha']);
删除多个会话
$_SESSION = array();
结束当前会话
session_destroy();

 手动设置session失效时间
 session_start();
 $time = 1*60;
 setcookie(session_name(),session_id(),time()+$time,"/");
 $_SESSION['user']="haha";

 
<?php
$session_name=session_name();
$session_id=$_GET[$sess_name];
session_id($session_id);
session_start();
$_SESSION['haha'] = "haha";
?>
 

cookie操作

设置cookie
setcookie("time",date("Y-m-d H:i:s"));
删除cookie
setcookie("time","",time()-1);

int SetCookie(string name,string value,int expire,string path,string domain,int secure);
除了name之外所有的参数都是可选的。value,path,domain 三个参数可以用空字符串代换,表示没有设置;expire和 secure两个参数是数值型的,可以用0表示。expire参数是一个标准的Unix时间标记,可以用time()或mktime() 函数取得,以秒为单位。secure参数表示这个Cookie是否通过加密的HTTPS协议在网络上传输。当前设置的Cookie 不是立即生效的,而是要等到下一个页面时才能看到.这是由于在设置的这个页面里Cookie由服务器传递给客户浏览器,在下一个页面浏览器才能把Cookie从客户的机器里取出传回服务器的原因。在同一个页面设置Cookie,实际是从后往前,所以如果要在插入一个新的Cookie之前删掉一个,你必须先写插入的语句,再写删除的语句,否则可能会出现不希望的结果。

 

 

 

你可能感兴趣的:(PHP,session,cookie)