有胆量你就来跟着路老师卷起来! -- 纯干货,技术知识分享
路老师给大家分享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连接数都有效 |
setcookie("mycookie",'www.phptest.lu'); setcookie("mycookie2",'www.phptest.lu',time()+60);//有效时间设置为60秒
编辑
1.4 读取Cookie
在PHP中可以直接通过超级全局数组$_COOKIE[]来获取客户端的Cookie的值。
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实现免密登录