cookie 的一个坑,自己记录一下

setcookie(‘name’,'test');
echo $_cookies['name'];

请说出程序结果(能说出第一次与第二次的区别者加分)

本来一开始我认为不就是设置一个cookie,然后读出来的问题,但是被那个后面的提示搞迷惑了从来没有想过这样的问题。 面试的时候也没有想出答案,后来在面试官的指点下搞清楚了。

答案:

第一次为空;
第二次输出 test.
解释:cookies是保存在客户端的,服务器要想获得cookie必须是客户端通过http的header传递给服务器。

第一次:首先设置一个cookie值,然后读取cookie值(由于第一次客户端没有传递cookie给服务器),没有cookie值
第二次:cookie值传递给了服务器,就读出来了
在面试官的指点后,我才想起来了之前有项目的bug与这个有关,但是换个方法避开了。

碰巧这几天看php手册看到了setcookie中有这样一段代码:

<?php
// set the cookies
setcookie("cookie[three]", "cookiethree");
setcookie("cookie[two]", "cookietwo");
setcookie("cookie[one]", "cookieone");

// after the page reloads, print them out
if (isset($_COOKIE['cookie'])) {
    foreach ($_COOKIE['cookie'] as $name => $value) {
        $name = htmlspecialchars($name);
        $value = htmlspecialchars($value);
        echo "$name : $value <br />\n";
    }
}
?> 

亮点
// after the page reloads, print them out => 在页重新加载后,打印出来
我想这个提示太低调了,我想我们很多人在在调试


在 justjavac 上看到的,我没看解释之前,也以为第一次输出的为 test
所以发表在这,记录下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值