這個標題不是很嚴格,應該說可以使用點號的cookie名,但會被轉換,你命名一個cookie:
$_COOKIE[‘my.name'] = 1;
實際上你不能通過’my.name’在cookie中查找到這個值,只能是’my_name’:
echo $_COOKIE[‘my_name'];
php已經自動幫你進行了轉化,句點轉為了下劃線。
php為什麼要這樣做呢?這是因為$_GET/$_POST/$_SERVER/$_COOKIE。。。這些全局函數的值,在之前的許多版本中是可以通過register_globals參數在本地中直接訪問這些值的,比如開啟register_globals = on後,訪問$my_name直接取值為1。如果是$my.name的話,則不符合php變量命名原則,這不單是句號(.)的問題。
因此,$_COOKIE的命名已經符合php命名標准。
另外開啟register_globals是一個很糟糕的決定,因為它可能會覆蓋腳本中原來的值,比如:
// other code if ($a) $uc_is_login = true; // ...用戶只需要發送一個url?a=1的http請求就可以默認已經登陸。這是個很危險的做法,應該把它關閉。實際上php6已經去除了這個選項。
網頁提交的時候會帶上cookie的,所以cookie一般不會放很大的東西,不然網頁會很慢。
這就是為什麼圖片等資源用和主站不一樣的域名。
樓上的思路,和session不是一樣的嘛。session就是每個用戶的session對應用戶唯一的PHPSESSID(在cookie中)。
給你一張http請求的圖片。
<?php
date_default_timezone_set("PRC");
setcookie("name","小羅",time()+3600);
echo "您的名字是:".$_COOKIE["name"];
?>