使用COOKIE和用户会话

COOKIE

COOKIE简介

由用户浏览器存储的少量数据
内容包含名字,值,过期时间已经主机和路径信息
一个单个主机可以请求保存20个cookie,每个cookie大小限制为4kb
cookie不应该作为基本元素而依赖

访问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

即使我们在脚本第一次运行的时候设置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'];         //输出空或者报错

你可能感兴趣的:(使用COOKIE和用户会话)