(o゜▽゜)o☆[BINGO!]

ok,我们先看看cookie是什么东东?

cookie是服务器留在客户端的用于识别用户或者存储一些数据的小文件(注意,session存储在服务器端,这是两者的区别之一)。我们平时登录某门户时,会有选项“是否保存登录”或者“下次自动登录”,当我们勾选了之后,服务器就会在我们的浏览器创建cookie文件来保存我们的信息。每当计算机通过浏览器请求页面时,它会同时发送cookie。通过PHP,可以创建并取回cookie的值。cookie在web中是很重要的角色,早在网景浏览器的时候就产生了cookie。cookie经常被用于用户验证系统。

1.创建cookie

函数setcookie()可以在PHP中生成cookie。由于cookie是HTTP头标部分的内容,因此必须在输出任何数据之前调用setcookie(),这个限制和header()类似,定义:

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):

<"test",China");
"color: #ff0000">只能是数字或者字符串,不能是其他的复杂结构。

2.获取cookie

创建cookie后,就可以使用预定义变量$_COOKIE来获取cookie。不过,只能在其他页面获取cookie,因为在php中,被设置的cookie不会在本页面生效,除非该页面被刷新。

实例:

<"test","China");
 echo "cookie is ".$_COOKIE["test"];
 "MathJax-Element-1-Frame" class="MathJax" role="presentation" tabindex="0" data-mathml="<math xmlns="http://www.w3.org/1998/Math/MathML"><msub><mi></mi><mi>C</mi></msub><mi>O</mi><mi>O</mi><mi>K</mi><mi>I</mi><mi>E</mi><mrow class="MJX-TeXAtom-ORD"><mo>&#x53D8;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x91CF;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x4E2D;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#xFF0C;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x800C;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x662F;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x968F;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x7740;</mo></mrow><mi>h</mi><mi>t</mi><mi>t</mi><mi>p</mi><mrow class="MJX-TeXAtom-ORD"><mo>&#x8BF7;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x6C42;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x88AB;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x53D1;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x9001;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x81F3;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x670D;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x52A1;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x5668;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#xFF0C;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x8FD9;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x65F6;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x5019;</mo></mrow><mi>c</mi><mi>o</mi><mi>o</mi><mi>k</mi><mi>i</mi><mi>e</mi><mrow class="MJX-TeXAtom-ORD"><mo>&#x7684;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x503C;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x624D;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x4F1A;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x51FA;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x73B0;</mo></mrow><mrow class="MJX-TeXAtom-ORD"><mo>&#x5728;</mo></mrow></math>" ismathjax="true" jaxid="HTML-CSS" style="position: relative; display: inline-block">_COOKIE中。

3.cookie的有效期

cookie有生命周期,也就是cookie存在的有效时间。可以设置第三个参数来设置有效时间。

实例(设置cookie有效时间的几种方式):

setcookie("cookie_one","A",time()+60*60);    //cookie在一小时后失效
setcookie("cookie_two","B",time()+60*60*24);  //cookie在一天后失效
setcookie("cookie_three","C",mktime(23,53,19,10,09,2020));  //cookie在2020年10月9日23时53分19秒失效
setcookie("cookie_four","D");   //关闭浏览器后cookie失效 

4.cookie的有效路径

cookie中的路径用来控制设置的cookie在哪个路径下有效,默认为'/',在所有路径下都有效,也就是在整个服务器域名下都有效,当设定了其他路径之后,则只在设定的路径以及子路径下有效,例如:

setcookie('test', time(), 0, '/path');

上面的设置会使test在/path以及子路径/path/abc下都有效,但是在根目录下就读取不到test的cookie值。

一般情况下,大多是使用所有路径的,只有在极少数有特殊需求的时候,会设置路径,这种情况下只在指定的路径中才会传递cookie值,可以节省数据的传输,增强安全性以及提高性能。

5.删除cookie

删除cookie比较简单,也是通过setcookie()来实现的(不要使用unset()!!!)下面的代码就是个简单例子:

setcookie("test","");

通过将第二个参数设为空来达到删除cookie的目的。如果设置cookie时,为cookie提供了特定的值,那么在删除cookie时,仍然需要提供这些参数,以便PHP可以正确地删除cookie。

以上这篇浅谈PHP Cookie处理函数就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!