例
下面的示例創建與PHP的cookie。 該cookie被命名為"user"和值將是"John Doe" 。 cookie的值不會被URL編碼。 經過30天的cookie將過期(86400 * 30) 使用"/"意味著該Cookie是在整個網站上提供(otherwise, select the directory you prefer) :
<?php
$cookie_name = "user";
$cookie_value = "John";
setrawcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/");
//
86400 = 1 day
?>
<html>
<body>
<?php
echo "Cookie is set.";
?>
</body>
</html>
?>
運行示例» 定義和用法
所述setrawcookie()函數定義一個cookie (without URL encoding)以沿著與所述HTTP標頭的其餘部分被發送。
Cookie通常用來識別用戶。 Cookie是服務器在用戶的計算機中的小文件。 每當計算機請求一個頁面瀏覽器時,它就會發送cookie。 使用PHP,您可以創建並取回cookie的值。
Cookie的名字被自動分配到同一名稱的變量。 例如,如果一個cookie用的名稱發送"user" ,一個變量被自動創建名為$用戶,包含cookie值。
Note:該setrawcookie()函數必須出現在之前<html>標記。
Note:要自動URL編碼發送時,並且自動接收時進行解碼,使用cookie值setcookie()函數來代替。
句法
setrawcookie( name,value,expire,path,domain,secure );
參數 | 描述 |
---|---|
name | 需要。 指定cookie的名稱 |
value | 可選的。 指定cookie的值 |
expire | 可選的。 指定當Cookie過期。 值: time() + 86400 * 30,將設置Cookie在30天后過期。 如果未設置此參數,cookie將在會議結束時到期(when the browser closes) |
path | 可選的。 規定cookie的服務器路徑。 如果設置為"/"時,cookie將是整個域內可用。 如果設置為"/php/"時,cookie將只能是php目錄和PHP的所有子目錄中可用。 默認值是該Cookie在所設定的當前目錄 |
domain | 可選的。 規定cookie的域名。 為了使在example.com的所有子域提供的餅乾,設置域".example.com" 。 如果設置為www.example.com將會使餅乾只在www子域可用 |
secure | 可選的。 規定是否該cookie只能通過安全的HTTPS連接來傳輸。 TRUE表明,如果安全連接存在cookie將只設置。 默認為false。 |
技術細節
返回值: | TRUE成功。 FALSE失敗 |
---|---|
PHP版本: | 5+ |
更多示例
例
檢索名為cookie的值"user" (使用全局變量$ _COOKIE)。 還可以使用isset()的功能,以找出是否該cookie存在:
<html>
<body>
<?php
$cookie_name = "user";
if(!isset($_COOKIE[$cookie_name]))
{
echo "Cookie named '" . $cookie_name . "' does not
exist!";
} else {
echo "Cookie is named: " . $cookie_name
. "<br>Value is: " . $_COOKIE[$cookie_name];
}
?>
</body>
</html>
運行示例» 例
要修改一個cookie,只需將(again)使用該cookie setrawcookie()函數:
<?php
$cookie_name = "user";
$cookie_value = "Alex";
setrawcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/");
?>
<html>
<body>
<?php
$cookie_name = "user";
if(!isset($_COOKIE[$cookie_name]))
{
echo "Cookie named '" . $cookie_name . "' does not
exist!";
} else {
echo "Cookie is named: " . $cookie_name
. "<br>Value is: " . $_COOKIE[$cookie_name];
}
?>
</body>
</html>
運行示例» 例
要刪除Cookie,使用setrawcookie()函數,在過去的到期日期:
<?php
$cookie_name = "user";
unset($_COOKIE[$cookie_name]);
// empty value and expiration one hour
before
$res = setrawcookie($cookie_name, '', time() - 3600);
?>
<html>
<body>
<?php
echo "Cookie 'user'
is deleted.";
?>
</body>
</html>
運行示例» 例
創建一個小的腳本來檢查是否cookies被啟用。 首先,嘗試創建一個測試Cookie與setrawcookie()函數,然後計算$ _COOKIE數組變量:
<?php
setrawcookie("test_cookie", "test" , time() + 3600, '/');
?>
<html>
<body>
<?php
if(count($_COOKIE) > 0) {
echo "Cookies are enabled";
} else {
echo "Cookies
are disabled";
}
?>
</body>
</html>
運行示例» <PHP HTTP參考