使用COOKIE和用户会话

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'];         //输出空或者报错
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 作者:晚晴幽草轩www.jeffjade.com/2016/10/31/115-summary-of-cookie...
    饥人谷_Dylan阅读 1,232评论 0 51
  • 背景在HTTP协议的定义中,采用了一种机制来记录客户端和服务器端交互的信息,这种机制被称为cookie,cooki...
    时芥蓝阅读 2,384评论 1 17
  • 会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话。常用的会话跟踪技术是Cookie与Se...
    chinariver阅读 5,666评论 1 49
  • 注:本文转载自前端大全 背景 在HTTP协议的定义中,采用了一种机制来记录客户端和服务器端交互的信息,这种机制被称...
    楠小忎阅读 689评论 0 0
  • Session的声明与使用 Session的设置不同于Cookie,必须先启动,在PHP中必须调用session_...
    寻回骄傲阅读 2,967评论 0 18