亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区
Chinaunix
標題:
從一道php面試題說起
[打印本頁]
作者:
凝望長空
時間:
2012-01-13 15:04
標題:
從一道php面試題說起
從一道php面試題說起
面試題目:
Php代碼
setcookie(‘name’,'test');
echo $_cookies['name'];
復制代碼
請說出程序結果(能說出第一次與第二次的區(qū)別者加分)
setcookie(‘name’,'test');
echo $_cookies['name'];
復制代碼
請說出程序結果(能說出第一次與第二次的區(qū)別者加分) 本來一開始我認為不就是設置一個cookie,然后讀出來的問題,但是被那個后面的提示搞迷惑了從來沒有想過這樣的問題。面試的時候也沒有想出答案,后來在面試官的指點下搞清楚了。
答案:
Php代碼
1.第一次為空
2.第二次輸出 test
復制代碼
解釋:cookies是保存在客戶端的,服務器要想獲得cookie必須是客戶端通過http的header傳遞給服務器。
第一次:首先設置一個cookie值,然后讀取cookie值(由于第一次客戶端沒有傳遞cookie給服務器),沒有cookie值
第二次:cookie值傳遞給了服務器,就讀出來了
1.第一次為空
2.第二次輸出 test
解釋:cookies是保存在客戶端的,服務器要想獲得cookie必須是客戶端通過http的header傳遞給服務器。
第一次:首先設置一個cookie值,然后讀取cookie值(由于第一次客戶端沒有傳遞cookie給服務器),沒有cookie值
第二次:cookie值傳遞給了服務器,就讀出來了
在面試官的指點后,我才想起來了之前有項目的bug與這個有關,但是換個方法避開了。
碰巧這幾天看php手冊看到了setcookie中有這樣一段代碼:
Php代碼
<?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
<?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
復制代碼
我想這個提示太低調了,我想我們很多人在在調試
Php代碼
setcookie(‘name’,'test');
echo $_cookies['name'];
setcookie(‘name’,'test');
echo $_cookies['name'];
復制代碼
第一次沒有值,然后刷新一下出來了,就以為沒問題了,就不想這個問題是為什么。
都說手冊很重要,但是手冊這么多東西,你能保證你看手冊的時候就一定會注意到這個地方的代碼。于是我很好奇,面試官是在什么情景下遇到這個問題的,于是問了一下面試官,得到了以下回答:
Php代碼
呵呵,認證 應該算 所有web項目的 最開始,也是最重要的一個環(huán)節(jié)。
所以,對認證這塊,需要很熟悉。
這個問題 主要是考 COOKIE 是什么時候被服務端發(fā)往瀏覽器, 瀏覽器又是什么時候傳遞給服務器的。
呵呵,認證 應該算 所有web項目的 最開始,也是最重要的一個環(huán)節(jié)。
所以,對認證這塊,需要很熟悉。
復制代碼
這個問題 主要是考 COOKIE 是什么時候被服務端發(fā)往瀏覽器, 瀏覽器又是什么時候傳遞給服務器的。
確實如果從這個角度出發(fā),就有可能發(fā)現(xiàn)這個問題。然后面試官也說,他也才知道手冊上有這個東西。
最后確實手冊很重要,但是也太低調了,如果你發(fā)現(xiàn)手冊中類似如此低調的問題,請分享一下,我也準備收集一下手冊中低調的問題。
作者:
第一夫人
時間:
2012-01-13 15:04
收藏了
歡迎光臨 Chinaunix (http://72891.cn/)
Powered by Discuz! X3.2