- 論壇徽章:
- 0
|
從一道php面試題說起
面試題目:
Php代碼- setcookie(‘name’,'test');
- echo $_cookies['name'];
復制代碼 請說出程序結(jié)果(能說出第一次與第二次的區(qū)別者加分)- setcookie(‘name’,'test');
- echo $_cookies['name'];
復制代碼 請說出程序結(jié)果(能說出第一次與第二次的區(qū)別者加分) 本來一開始我認為不就是設置一個cookie,然后讀出來的問題,但是被那個后面的提示搞迷惑了從來沒有想過這樣的問題。面試的時候也沒有想出答案,后來在面試官的指點下搞清楚了。
答案:
Php代碼解釋: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
復制代碼 我想這個提示太低調(diào)了,我想我們很多人在在調(diào)試
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)這個問題。然后面試官也說,他也才知道手冊上有這個東西。
最后確實手冊很重要,但是也太低調(diào)了,如果你發(fā)現(xiàn)手冊中類似如此低調(diào)的問題,請分享一下,我也準備收集一下手冊中低調(diào)的問題。
|
|