22 Cookie

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 路老师在知乎上分享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实现免密登录

相关文章
|
12月前
|
机器学习/深度学习 计算机视觉
RT-DETR改进策略【注意力机制篇】| ICLR2023 高效计算与全局局部信息融合的 Sea_Attention 模块(含HGBlock二次创新)
RT-DETR改进策略【注意力机制篇】| ICLR2023 高效计算与全局局部信息融合的 Sea_Attention 模块(含HGBlock二次创新)
349 2
RT-DETR改进策略【注意力机制篇】| ICLR2023 高效计算与全局局部信息融合的 Sea_Attention 模块(含HGBlock二次创新)
|
机器学习/深度学习 人工智能
8个特征工程技巧提升机器学习预测准确性
8个特征工程技巧提升机器学习预测准确性
8个特征工程技巧提升机器学习预测准确性
|
监控 UED
产品经理-设计生命周期 - AxureMost
设计生命周期涵盖从概念构思到产品退役的全过程,分为概念与规划、设计与开发、测试与验证、市场推出、维护与优化及衰退与退役六个阶段。每个阶段有特定目标和挑战,确保产品始终围绕用户需求和市场动态调整,保持竞争力。设计团队需灵活应对各阶段任务,以实现产品的成功。
250 17
|
芯片 开发者
脉冲宽度调制
脉冲宽度调制(PWM)是一种通过调整脉冲信号的占空比来控制功率、亮度或速度等参数的技术,广泛应用于电机控制、电源转换和照明等领域。
|
机器学习/深度学习 传感器 自动驾驶
使用Python实现深度学习模型:智能车联网与自动驾驶
【8月更文挑战第14天】 使用Python实现深度学习模型:智能车联网与自动驾驶
836 10
|
XML 设计模式 Java
PowerMock:静态方法与私有方法测试
PowerMock是Java单元测试中扩展Mockito的框架,允许模拟静态方法、构造函数、私有方法和final类,以增强测试隔离和覆盖率。主要应用场景包括静态方法模拟、私有方法测试和构造函数/Final类模拟。然而,使用时需注意配置复杂性、避免过度使用、精确控制模拟行为和遵循最佳实践。示例展示了如何模拟静态方法,通过添加PowerMock依赖和使用PowerMockito.mockStatic进行静态方法的模拟和验证。正确使用PowerMock能提升测试质量,但应谨慎以保持代码可读性和测试有效性。
721 5
PowerMock:静态方法与私有方法测试
|
存储 缓存 监控
MySQL 8.0中查询缓存的废弃与原因分析
MySQL 8.0中查询缓存的废弃与原因分析
899 1
|
数据库 开发者 Java
颠覆传统开发:Hibernate与Spring Boot的集成,让你的开发效率飞跃式提升!
【8月更文挑战第31天】在 Java 开发中,Spring Boot 和 Hibernate 已成为许多开发者的首选技术栈。Spring Boot 简化了配置和部署过程,而 Hibernate 则是一个强大的 ORM 框架,用于管理数据库交互。将两者结合使用,可以极大提升开发效率并构建高性能的现代 Java 应用。本文将通过代码示例展示如何在 Spring Boot 项目中集成 Hibernate,并实现基本的数据库操作,包括添加依赖、配置数据源、创建实体类和仓库接口,以及在服务层和控制器中处理 HTTP 请求。这种组合不仅简化了配置,还提供了一套强大的工具来快速开发现代 Java 应用程序。
1041 1
|
存储 安全 测试技术
《手把手教你》系列技巧篇(六十三)-java+ selenium自动化测试 - cookie -上篇(详细教程)
【6月更文挑战第4天】本文介绍了Cookie和Session的概念及其用途。Cookie是服务器发送到浏览器并存储在本地的小型文本文件,用于记录用户信息,如登录状态。它分为会话Cookie(关闭浏览器即消失)和永久Cookie(设置过期时间)。Session则是在服务器端保存用户状态的一种方式,比Cookie更安全,但会占用服务器资源。Selenium提供了操作Cookie的API,包括添加、删除和获取Cookie。文章还提到了Cookie的优缺点,如大小限制和潜在的安全风险。
399 1
《手把手教你》系列技巧篇(六十三)-java+ selenium自动化测试 - cookie -上篇(详细教程)
|
Java PHP 数据安全/隐私保护
php base64_decode与java base64解密结果不匹配问题
php base64_decode与java base64解密结果不匹配问题
481 0