作者:十字心死_823 | 来源:互联网 | 2018-07-17 16:38
(o゜▽゜)o☆[BINGO!]
ok,我们先看看COOKIE是什么东东?
COOKIE是服务器留在客户端的用于识别用户或者存储一些数据的小文件(注意,session存储在服务器端,这是两者的区别之一)。我们平时登录某门户时,会有选项“是否保存登录”或者“下次自动登录”,当我们勾选了之后,服务器就会在我们的浏览器创建COOKIE文件来保存我们的信息。每当计算机通过浏览器请求页面时,它会同时发送COOKIE。通过PHP,可以创建并取回COOKIE的值。COOKIE在web中是很重要的角色,早在网景浏览器的时候就产生了COOKIE。COOKIE经常被用于用户验证系统。
1.创建COOKIE
函数setCOOKIE()可以在PHP中生成COOKIE。由于COOKIE是HTTP头标部分的内容,因此必须在输出任何数据之前调用setCOOKIE(),这个限制和header()类似,定义:
1 bool setCOOKIE( string name[,string value][,int expire][,string path][,string domain][,bool secure][,bool httponly])
好多参数啊!Σ(⊙▽⊙"a 不急,让我们看看各个参数的作用:
name : 必选,表示COOKIE的名字。
value : 可选,表示COOKIE值,存储在客户端,当为空时,表示撤销客户端中该COOKIE的资料(这样可以删除COOKIE)。
expire : 可选,表示COOKIE的有效截止时间,也就是过期时间,如果没有指定或者指定为0,那么通常是在关闭浏览器时失效。
path : 可选,COOKIE有效路径。
domain : 可选,COOKIE有效域名。
secure : 表示在HTTPS的安全传输时才有效。
实例(建立一个名字为test,值为China的COOKIE):
1 php
2 setCOOKIE("test",China");
3 ?>
使用setCOOKIE()给的值只能是数字或者字符串,不能是其他的复杂结构。
2.获取COOKIE
创建COOKIE后,就可以使用预定义变量$_COOKIE来获取COOKIE。不过,只能在其他页面获取COOKIE,因为在php中,被设置的COOKIE不会在本页面生效,除非该页面被刷新。
实例:
1 php
2 setCOOKIE("test","China");
3 echo "COOKIE is ".$_COOKIE["test"];
4 ?>
这里之所以要刷新页面,是因为COOKIE的值不会在调用setCOOKIE()之后立即存储在$_COOKIE变量中,而是随着http请求被发送至服务器,这时候COOKIE 的值才会出现在$_COOKIE中。
3.COOKIE的有效期
COOKIE有生命周期,也就是COOKIE存在的有效时间。可以设置第三个参数来设置有效时间。
实例(设置COOKIE有效时间的几种方式):
1 setCOOKIE("COOKIE_one","A",time()+60*60); //COOKIE在一小时后失效
2 setCOOKIE("COOKIE_two","B",time()+60*60*24); //COOKIE在一天后失效
3 setCOOKIE("COOKIE_three","C",mktime(23,53,19,10,09,2020)); //COOKIE在2020年10月9日23时53分19秒失效
4 setCOOKIE("COOKIE_four","D"); //关闭浏览器后COOKIE失效
4.COOKIE的有效路径
COOKIE中的路径用来控制设置的COOKIE在哪个路径下有效,默认为'/',在所有路径下都有效,也就是在整个服务器域名下都有效,当设定了其他路径之后,则只在设定的路径以及子路径下有效,例如:
1 setCOOKIE('test', time(), 0, '/path');
上面的设置会使test在/path以及子路径/path/abc下都有效,但是在根目录下就读取不到test的COOKIE值。
一般情况下,大多是使用所有路径的,只有在极少数有特殊需求的时候,会设置路径,这种情况下只在指定的路径中才会传递COOKIE值,可以节省数据的传输,增强安全性以及提高性能。
5.删除COOKIE
删除COOKIE比较简单,也是通过setCOOKIE()来实现的(不要使用unset()!!!)下面的代码就是个简单例子:
1 setCOOKIE("test","");
通过将第二个参数设为空来达到删除COOKIE的目的。如果设置COOKIE时,为COOKIE提供了特定的值,那么在删除COOKIE时,仍然需要提供这些参数,以便PHP可以正确地删除COOKIE。