phpでCookieを削除する効果的な方法
Cookieの削除手順を開始-----
bool setcookie ( 文字列名 [, 文字列値 [, int 期限切れ [, 文字列パス [, 文字列ドメイン [, bool secure]]]]] )
Cookie を削除するには、ブラウザの削除メカニズムをトリガーするために、Cookie の有効期限が過去であることを確認する必要があります。
次の例は、設定したばかりの Cookie を削除する方法を示しています:
//有効期限を 1 時間前に設定します
setcookie("TestCookie",
"", time() - 3600);
setcookie("TestCookie", "", time() - 3600, "/~rasmus/",
".utoronto.ca", 1);
?>
-----Cookie の削除手順は終了-----
Cookie を削除する方法は、Cookie の有効期間を現在時刻より前に設定することです。これは、ほとんどすべての PHP プログラマーが行っていることです。
その後、PHP を初めて使用した友人が、プログラム内で Cookie の値を空に設定したいと言いましたが、Cookie は直接削除されました。当時の私の最初の反応は、信じられないということでしたので、テストしてみました:
setcookie("testcookie",
'');
print_r($_COOKIE);
その結果、$_COOKIE['testcookie'] だけでなく、$_COOKIE 配列全体が空になります。そこで、winsock を使用してパケットをキャプチャし、返された http ヘッダーを観察したところ、http ヘッダーが「Set-Cookie:」であることがわかりました。
テストクッキー=削除済み; 期限切れ=月、2007 年 6 月 18 日 02:42:33
GMT"、つまり「setcookie("testcookie",
'');'' は確かに testcookie クッキーを直接削除しますが、この状況については PHP マニュアルにはまったく説明がありません。
最後に、PHPのソースコードを読んで、ようやく真実を発見しました(これがオープンソースの利点です。不明な裏話がある場合は、ソースコードを直接確認してください)。
次のコードは、php5.20 の Linux ソース パッケージの ext/standard/head.c の 99 行目付近にあります。
if (value && value_len == 0) { /*
* MSIE は Cookie を設定しても削除しません
null 値にします
* クッキーを強制的に削除するため、
MSIE、私たち
* 過去 1 年 1 秒前の有効期限を選択します
*/
time_t t = time(NULL) - 31536001;
dt = php_format_date("D,
d-M-Y H:i:s T", sizeof("D, d-M-Y H:i:s T")-1, t, 0 TSRMLS_CC);
sprintf(cookie, "Set-Cookie: %s=削除; 期限切れ=%s", name, dt);
efree(dt);
} else {
sprintf(cookie, "Set-Cookie: %s=%s", name, value?
encoded_value : "");
if (有効期限 > 0) {
strcat(cookie, ";
期限切れ =);
dt = php_format_date("D, d-M-Y H:i:s T", sizeof("D, d-M-Y
H:i:s T")-1、期限切れ、0 TSRMLS_CC);
strcat(cookie, dt);
efree(dt);
}
}
最後に、「setcookie($cookiename, '');」または「setcookie($cookiename,
NULL);" は Cookie を削除しますが、もちろんこれらのマニュアルには記載されていません。
出典: http://www.111cn.net/phper/21/f0eace11b1229a0f2c7c54e3c1ea4654.htm
http://www.bkjia.com/PHPjc/918673.html