22 Cookie

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容Redis),内存型 2GB
简介: 路老师在知乎上分享PHP语言的知识,帮助大家入门并深入了解PHP。本文主要介绍Cookie的概念、功能及管理方法,包括如何创建、读取、删除Cookie,以及Cookie的生命周期等内容。纯干货,技术知识分享。

有胆量你就来跟着路老师卷起来! -- 纯干货,技术知识分享

路老师给大家分享PHP语言的知识了,旨在想让大家入门PHP,并深入了解PHP语言。

image.gif 编辑


上一篇文章结束了PDO后,本文我们准备说一下cookie。不过什么是cookie呢?当我们运行一个应用程序的时候,打开它并进行某些操作,然后关闭它,这个过程很像一次会话。计算机清楚你是谁,它知道何时启动应用程序,并在何时终止,但是在Internet上,存在一个问题:服务器不知道你是谁以及你做了什么,这是因为HTTP地址不能维持状态,所以需要通过在服务器上存储用户信息以便后面使用,这时候cookie和session就出现了,这两个可以临时保存会话信息,方便用户操作。

1 Cookie管理

Cookie是在HTTP协议下,服务器或者脚本维护客户工作站上信息的一种方式。Cookie的使用很普遍,许多提供个人化服务的网站都是利用Cookie来区别不同用户,以显示与用户相应的内容。有效地使用Cookie可以轻松完成很多复杂任务。

1.1 了解Cookie

Cookie是一种在远程浏览器端存储数据并以此来跟踪和识别用户的机制。简单地说,Cookie是Web服务器暂时存储在用户硬盘上的一个文本文件,并被Web浏览器读取。当用户再次访问Web网站时,网站通过读取Cookie文件记录这位访客的特定信息(如上次的访问位置花费的时间用户名密码等),从而迅速做出响应,如在网站免密登录。

比如你打开google浏览器的设置页面搜索cookie就会出现下列内容:

image.gif 编辑

1.2 Cookie的功能

Web服务器可以应用Cookie包含信息的任意性来筛选并经常性维护这些信息,并以此判断在HTTP传输中的状态。Cookie常用于以下3个方面:

  • 记录方可的某些信息。
  • 在页面之间传递变量
  • 将查看的网页存储在Cookie临时文件夹中,提高以后的浏览速度。

注意:一般不要用Cookie保存数据集或者其他量大的数据。并非所有的浏览器都支持Cookie,并且数据信息是以明文文本的形式保存在客户端计算机中,因此最好不要保存敏感的或者未加密的数据,否则会影响网络的安全性。

1.3 创建Cookie

在PHP中通过setcookie()函数创建Cookie。在创建Cookie之前必须了解的是,Cookie是HTTP头标的组成部分,而头标必须在页面其他内容之前发送,它必须最先输出。若在setcookie()函数前输出一个HTML标签或者echo语句,甚至一个空行都会导致程序出错。

bool setcookie(string name[,string value[,int expire[,string path[,string domain[,int secure]]]]]);

image.gif

其参数说明如下:

参数 说明 举例
name Cookie的变量名 可以通过$_COOKIE["cookiename"]调用变量名为cookiename的Cookie
value Cookie变量的值,该值保存在客户端,不能用来保存敏感数据 可以通过$_COOKIE["values"]获取名为values的值
expire Cookie的失效时间,expire是标准的UNIX时间标记,可以用time()函数获取,单位为秒 如果不设置Cookie失效时间,Cookie将永久有效,除非手动删除
path Cookie在服务器端的有效路径 如果该参数设置为“/”,则它在整个domain内有效,如果设置为“/11”,则它在domain下的/11目录及子目录内有效,默认是当前目录。
domain Cookie有效的域名 如果要使Cookie在xxx.com域名下的所有子域都有效,则domain的值应该设置为xxx.com
secure

指明Cookie是否仅通过安全的HTTPS,值为0或者1

如果值是1,则Cookie只能在HTTPS连接上有效;值为0,则Cookie在HTTP和HTTPS连接数都有效
<?php
  setcookie("mycookie",'www.phptest.lu');
  setcookie("mycookie2",'www.phptest.lu',time()+60);//有效时间设置为60秒
?>

image.gif

image.gif 编辑

1.4 读取Cookie

在PHP中可以直接通过超级全局数组$_COOKIE[]来获取客户端的Cookie的值。

<?php
date_default_timezone_set('PRC');
//如果cookie不存在,那就是第一次访问网站
if(!isset($_COOKIE["visittime"])){
    setcookie("visittime",date("Y-m-d H:i:s"));
    echo "欢迎首次访问nb的网站!";
    echo "<br>";
}else{
    setcookie("visittime",date("Y-m-d H:i:s"),time()+60);
     echo "您上次访问网站的时间为:".$_COOKIE["visittime"];
     echo "<br>";
}
 echo "您本次访问网站的时间为: ".date("Y-m-d H:i:s");
    
    
    
?>

image.gif

首次预览网站的时候显示这样:

image.gif 编辑

刷新页面如下: (等过了60秒后又会恢复到上个图的首次欢迎界面)

image.gif 编辑

1.5 删除Cookie

当Cookie被创建后,如果没有设置失效时间,Cookie文件会在关闭浏览器的时候被自动删除,如果要在关闭浏览器之前删除Cookie文件,有两种方法:一种是使用setcookie()函数删除,一种是在浏览器手动删除。

使用setcookie()函数删除cookie只需要在setcookie()函数中的第二个参数设置成为空值,将第三个参数Cookie的过期时间设置为小于系统当前时间即可。

setcookie("name","",time()-1);

image.gif

在上述代码中,time函数返回以秒表示的时间戳,把过期时间减去1就会得到过去的时间,从而可以实现删除Cookie的作用。

1.6 Cookie的生命周期

  • 如果Cookie不设定时间,就表示它的生命周期为浏览器会话的时间,只要关闭浏览器,cookie就会自动消失,这种叫会话Cookie,一般不保存在硬盘上,而是保存在内存中。
  • 如果设置了过期时间,那么浏览器就会把Cookie保存到硬盘,再次打开浏览器就会依然有效,直到它过期。
  • 虽然Cookie可以长期保存在客户端浏览器中,但是也不是一成不变的。因为浏览器最多允许存储300个Cookie文件,而且每个Cookie文件支持的最大容量是4KB;每个域名最多支持20个Cookie,如果达到限制,浏览器会随机自动删除Cookie。

下一篇 Cookie实现免密登录

相关文章
|
8月前
|
存储 安全
什么是Cookie与Session之Cookie详解
什么是Cookie与Session之Cookie详解
87 0
|
8月前
|
存储 缓存 物联网
新EDPB指南:不只是Cookie
保障中国企业符合《个人信息保护法》合规,方案包括梳理基线、发现敏感信息、简化评估工作流、快速响应权利请求、满足告知同意要求,以及有效保护敏感数据。用九智汇整合自动化工具和规则引擎,确保高效风险评估、合规证据链建立,进一步保障数据安全。
89 1
|
存储 安全 算法
96 # cookie
96 # cookie
61 0
|
存储 编解码 应用服务中间件
Cookie浅谈
Cookie浅谈
91 0
向Cookie里添加东西
向Cookie里添加东西
89 0
|
存储 Web App开发 API
Cookie
Cookie
86 0
|
存储 JavaScript 前端开发
Cookie 剖析
Cookie 剖析
137 0
|
Web App开发 安全 JavaScript
Hostonly cookie是什么鬼?
知道cookie hostonly属性的请举手🧐
Hostonly cookie是什么鬼?