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學習者快速成長!