最新的Web開發教程
 

PHP setrawcookie() Function

<PHP HTTP參考

下面的示例創建與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參考