COOKIE
COOKIE简介
由用户浏览器存储的少量数据
内容包含名字,值,过期时间已经主机和路径信息
一个单个主机可以请求保存20个cookie,每个cookie大小限制为4kb
<u>cookie不应该作为基本元素而依赖</u>
访问COOKIE
cookie在环境变量 HTTP_COOKIE
中或者作为 $_COOKIE
超全局变量的一部分,通过如下三种方式访问它们
* echo $_SERVER['HTTP_COOKIE'];
* echo getenv('HTTP_COOKIE');
* echo $_COOKIE['vegetable'];
在JavaScript中,可以通过 document.cookie
访问 cookie
设置COOKIE
用两种方式在PHP脚本中设置COOIKIE
- 通过
header()
函数设置Set-Cookie标头 - 通过
setcookie()
函数设置COOKIE
<?php
setcookie("name","jack",time()+3600,"/","xxx.com",0);
if(isset($_COOKIE['name'])){
echo "$_COOKIE['name']";
}
else
echo "This is first visit";
//函数接受cookie名字,cookie值,过期日期,路径,域以及一个整数(安全参数)
?>
即使我们在脚本第一次运行的时候设置cookie,$_COOKIE['name']
变量在这时也不会被创建。由于只有当浏览器将一个cookie发送到服务器的时候才会读取它,因此,直到用户重新访问这个域内的一个页面时,我们才能够读取它
过期时间以UNIX时间戳为格式(从1970年到当前时间的秒数),time()
函数可以获取当前时间的时间戳
删除COOKIE
通过 name
参数调用 setcookie()
可以重新设置所有存储的值
要绝对确保你的cookie不再有效,或者存储任意的值,也可以使用一个过期的时间戳设置cookie
setcookie("name","",time()-60,"/","xxx.com",0)
通过这种方式删除cookie时,确保传递与最初设置时相同的路径,域名和安全参数
会话
服务器端会话为用户提供一个唯一的标识符,随后可以用来存储和获取连接到该标识符的信息。任何已经和会话相关联的变量,都通过 $_SESSION
超全局变量变得可供使用。
要使用一个会话,我们要显式地开始或者继续会话。默认情况下,会话不会自动启动。
可以在php.ini文件中找到session.auto_start = 0
将其改为1使得会话自动启动
会话启动函数session_start()
会话启动之后,可以立即通过 session_id()
函数访问用户的会话id
使用会话变量
当一个会话启动后,我们可以在超全局变量 _SEDSSION
中存储任意多的变量
销毁会话和重置变量
可以用 session_destory()
函数来结束一个会话,消除所有的会话变量。(在当前脚本结束前,会话变量不会被立即销毁)
session_start();
$_SESSION['test']=5;
session_destory();
echo $_SESSION['test']; //输出5
要从一个会话中删除所有已注册变量,只需要简单的重置变量:
session_start();
$_SESSION['test']=5;
session_destory();
unset($_SESSION['test']);
echo $_SESSION['test']; //输出空或者报错