PHP 5.5.9版本中COOKIE的奇怪现象

WBOY
发布: 2016-06-06 20:24:19
原创
1303 人浏览过

我在localhost下建了四个文件

<code>/1.php
/a/1.php
/test/1.php
/test/a/1.php</code>
登录后复制
登录后复制

文件中的代码都是一样的

<code><?php setcookie( __DIR__ ,__DIR__ );
var_dump($_COOKIE);</code></code>
登录后复制
登录后复制

我本以为,所有页面打开后,反复刷新,直到所有的cookie都设置完,结果应该是一样的。
但实际上不是

<code>/1.php            array(1) { ["/var/www/html"]=> string(13) "/var/www/html" } 


/a/1.php            array(2) { ["/var/www/html/a"]=> string(15) "/var/www/html/a" ["/var/www/html"]=> string(13) "/var/www/html" } 


/test/1.php       array(2) { ["/var/www/html/test"]=> string(18) "/var/www/html/test" ["/var/www/html"]=> string(13) "/var/www/html" } 


/test/a/1.php      array(3) { ["/var/www/html/test/a"]=> string(20) "/var/www/html/test/a" ["/var/www/html/test"]=> string(18) "/var/www/html/test" ["/var/www/html"]=> string(13) "/var/www/html" } </code>
登录后复制
登录后复制

明显看出 php的$__COOKIE 获取的cookie是文件所在层级到根目录,这个范围中设置的cookie。而更深层的文件设置的cookie和平级但不同目录的文件设置的cookie,是获取不到的。
我想问
假设 /test/1.php 文件要获取/test/a/1.php 文件设置的cookie,怎么做到呢?
这种现象出现的原理是什么呢?

回复内容:

我在localhost下建了四个文件

<code>/1.php
/a/1.php
/test/1.php
/test/a/1.php</code>
登录后复制
登录后复制

文件中的代码都是一样的

<code><?php setcookie( __DIR__ ,__DIR__ );
var_dump($_COOKIE);</code></code>
登录后复制
登录后复制

我本以为,所有页面打开后,反复刷新,直到所有的cookie都设置完,结果应该是一样的。
但实际上不是

<code>/1.php            array(1) { ["/var/www/html"]=> string(13) "/var/www/html" } 


/a/1.php            array(2) { ["/var/www/html/a"]=> string(15) "/var/www/html/a" ["/var/www/html"]=> string(13) "/var/www/html" } 


/test/1.php       array(2) { ["/var/www/html/test"]=> string(18) "/var/www/html/test" ["/var/www/html"]=> string(13) "/var/www/html" } 


/test/a/1.php      array(3) { ["/var/www/html/test/a"]=> string(20) "/var/www/html/test/a" ["/var/www/html/test"]=> string(18) "/var/www/html/test" ["/var/www/html"]=> string(13) "/var/www/html" } </code>
登录后复制
登录后复制

明显看出 php的$__COOKIE 获取的cookie是文件所在层级到根目录,这个范围中设置的cookie。而更深层的文件设置的cookie和平级但不同目录的文件设置的cookie,是获取不到的。
我想问
假设 /test/1.php 文件要获取/test/a/1.php 文件设置的cookie,怎么做到呢?
这种现象出现的原理是什么呢?

你去看下setcookie的文档。
setcookie的第三个参数path可以定义cookie生效的目录。 把path设置成/, 就说明cookie可以在域名下公用。

这种现象防止cookie变量冲突,也更安全。

相关标签:
php
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!