|
下面我們通過程序來看一下php cookie的使用,也許你看完上面那段還納悶,這個和cookie有什么聯系呢?
大體說一下在我們的MVC結構中所用的登陸驗證:
在controller中的構造函數用有一個專門驗證登陸的函數,根據模塊是否需要登陸驗證來加如此函數。
bug程序:在setcookie后,當前頁面進行了登陸驗證。
bug原因:當前頁面是獲得不了在此頁剛剛設置的cookie的
下面我們來用程序測試一下:
這里是一個設置cookie的函數,我們現在用的,偷懶了 呵呵
復制代碼 代碼如下:
function dsetcookie($var, $value, $life = 0) {
global $_cookie_domain, $_cookie_path, $_timestamp, $_SERVER;
setcookie($var, escape($value), $life ? $_timestamp + $life : 0,
$_cookie_path, $_cookie_domain, $_SERVER['SERVER_PORT'] == 443 ? 1 : 0);
}
然后建立test1.php,內容如下:
復制代碼 代碼如下:
<?php
$td = date('d');
dsetcookie("testvar",$td,30*24*60*60);
print_r($_COOKIE);
?>
將會得到一個空的數組array();
那我們在設置完后什么時候才能第一次使用這個$_COOKIE變量呢?
現在我們把test1.php這個程序稍微改動一下:
復制代碼 代碼如下:
<?php
$td = date('d');
dsetcookie("testvar",$td,30*24*60*60);
print_r($_COOKIE);//這個要注釋掉 要不然會報header警告
$location = "test2.php";
header("Location: ".$location);
?>
然后我們在test2.php中來顯示$_COOKIE看一下
復制代碼 代碼如下:
<?php
print_r($_COOKIE);
?>
這里我們將會得到:
Array
(
[testvar] =10
)
這里就能夠獲得并使用這個cookie值了。
為什么呢?
你可以這么理解:當前設置的Cookie不是立即生效的,而是要等到下一個頁面時才能看到.
這是由于在設置的這個頁面里Cookie由服務器傳遞給客戶瀏覽器,在下一個頁面瀏覽器才能把Cookie從
客戶的機器里取出傳回服務器的原因。
先寫到這里:
你可以通過下面的幾個鏈接更加深入的了解一下COOKIE
php COOKIE及其使用
NETscape公司關于Cookie的官方原始定義的網址:http://www.NETscape.com/newsref/std/cookie_spec.html
php技術:php cookie 作用范圍不要在當前頁面使用你的cookie,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。