在php 中cookie是我们常用到的,但是可能很多朋友都不知道cookie是怎么工作的,下面小编来给大家整理一下关于php cookie工作原理与一些对于cookie读写操作实例。
Cookie 是一小段文本信息,伴随着用户请求和页面在 Web 服务器和浏览器之间传递。用户每次访问站点时,Web 应用程序都可以读取 Cookie 包含的信息。 Cookie 的基本工作原理如果用户再次访问站点上的页面,当该用户输入 URLwww.*****.com时,浏览器就会在本地硬盘上查找与该 URL 相关联的 Cookie。如果该 Cookie 存在,浏览器就将它与页面请求一起发送到您的站点。
Cookie 有哪些用途?
最根本的用途是:Cookie 能够帮助 Web 站点保存有关访问者的信息。更概括地说,Cookie 是一种保持Web 应用程序连续性(即执行“状态管理”)的方法.使 Web 站点记住您.
•当客户访问某个基于PHP技术的网站时,在PHP中可以使用setcookie()函数生成一个cookie,系统经处理把这个cookie发送到客户端并保存在C:Documents andSettings用户名Cookies目录下。
•cookie是HTTP标头的一部分,因此setcookie()函数必须在HTML本身的任何内容送到浏览器之前调用。这种限制与header()函数一样(如需了解head()函数,请自行查阅)。
•当客户再次访问该网站时,浏览器会自动把C:DocumentsandSettings用户名Cookies目录下与该站点对应的cookie发送到服务器,服务器则把从客户端传来的cookie将自动地转化成一个PHP变量。在PHP5中,客户端发来的cookie将被转换成全局变量。你可以通过$_COOKIE[‘xxx’]读取。
定义Cookie:
设置Cookie:
bool setcookie(stringname,[stringvalue,[int expire,[stringpath,[stringdomain,[int secure]]]]]);
实例:
$value="the best way is by yourself"; setcookie("cookiename",$value,time()+60*60*24*7);
关于setcookie()函数的参数说明:
参数描述
name必需。规定 cookie 的名称。
value必需。规定 cookie 的值。
expire可选。规定 cookie 的有效期。
path可选。规定 cookie 的服务器路径。
domain可选。规定 cookie 的域名。
secure可选。规定是否通过安全的 HTTPS 连接来传输 cookie。
删除Cookie:
要删除一个已经存在的cookie,有两个办法:
1、调用只带有name参数的setcookie,那么名为这个name的cookie将被从客户机上删掉;
setcookie(“MyCookie”);//删除MyCookie
2、设置过期时间就行,那么这个Cookie在这个页面的浏览完之后就被删除了(其实是失效了)。
setcookie(“MyCookie”,”Value”,time()-1);
注意:当一个cookie被删除时,它的值在当前页面仍然有效。如果要把cookie设置成在浏览器关闭后就失效,那么可以直接把expiretime设为0,或者不设置此值。例如:setcookie("name","value",0);
cookie注意事项
•1、setcookie()之前不能有任何html输出,就是空格,空白行都不行,
必须在html文件的内容输出前设置
•2、setcookie()后,你在当前页调用echo $_COOKIE[“name”]不会有输出。
必须刷新或到下一个页面才可以看到cookie值。
•3、不用浏览器对cookie处理不同。客户端可以禁用cookie,浏览器也会限
制cookie的数量。一个浏览器能创建的cookie数量最多为300个,并且每个
不能超过4KB,每个WEB站点能设置的cookie总数不能超过20个。
•4、cookie是保存在客户端的,用户禁用了cookie,你的cookie自然也就没作
用啦!因此,避免过度依赖cookie,要先想好如果cookie被禁用时的解决方案,
以备万一。