入门PHP就来我这(高级)21 ~ Cookie

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

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

 


 自上一篇文章结束了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就会出现下列内容:

 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]]]]]);

其参数说明如下:

参数 说明 举例
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秒

?>

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");
    
    
    
?>

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

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

 1.5 删除Cookie

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

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

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

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

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

 下一篇 Cookie实现免密登录


大家如果喜欢技术,并想有个好的交流平台可以关注我的 我的知乎首页,会不定期分享本人觉得比较好的技术类电子书。

另外,自己创建的一个技术qq群,玩转技术群,该群里功能:分享技能,电子书,源代码,以及兼职项目等交流,欢迎大家加入一起交流。

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-10 21:04:06       100 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-10 21:04:06       107 阅读
  3. 在Django里面运行非项目文件

    2024-07-10 21:04:06       90 阅读
  4. Python语言-面向对象

    2024-07-10 21:04:06       98 阅读

热门阅读

  1. 纤程和协程理解

    2024-07-10 21:04:06       28 阅读
  2. 几款常见的数字孪生引擎

    2024-07-10 21:04:06       22 阅读
  3. C++:cv.absdiff函数含义

    2024-07-10 21:04:06       29 阅读
  4. 自动回复机器人:源码搭建与智能化客户服务

    2024-07-10 21:04:06       27 阅读
  5. 社群管理新助手:导航群机器人的智能化功能

    2024-07-10 21:04:06       31 阅读
  6. STAR 命令参数解释

    2024-07-10 21:04:06       27 阅读
  7. hid-ft260驱动学习笔记 4 - ft260_uart_ops

    2024-07-10 21:04:06       23 阅读
  8. Git详解

    Git详解

    2024-07-10 21:04:06      21 阅读