色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

php cookie 作用范圍不要在當前頁面使用你的cookie

因為在本地測試完全沒有問題,所以ssh到遠程服務器上(不是發布服務器,建議不要直接在Publish Server上直接改東西),進行了一下斷點的測試,最后發現是一個比較復雜的邏輯中有個函數在構造函數中調用了登陸驗證。沒有驗證通過所以就跳走了。
下面我們通過程序來看一下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,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 恩平市| 利辛县| 西藏| 大港区| 扎兰屯市| 孝昌县| 沿河| 汶川县| 航空| 新河县| 玉田县| 图木舒克市| 富平县| 铅山县| 准格尔旗| 麟游县| 文登市| 长白| 鸡东县| 图木舒克市| 龙海市| 自治县| 沭阳县| 类乌齐县| 山西省| 通榆县| 杭锦后旗| 莱芜市| 甘南县| 隆林| 兴义市| 衡阳县| 徐水县| 遂宁市| 万年县| 玛纳斯县| 武鸣县| 景宁| 包头市| 增城市| 贡觉县|