PHPでCookieが削除できない

王林
リリース: 2023-02-24 10:10:02
オリジナル
3917 人が閲覧しました

PHPでCookieが削除できない

まず、関連する Cookie のメカニズムを見てみましょう。

bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure]]]]] )
ログイン後にコピー

Cookie を削除するには、ブラウザの削除メカニズムをトリガーするために、Cookie の有効期限が過去であることを確認する必要があります。

次の例は、設定したばかりの Cookie を削除する方法を示しています。

<?php
//将过期时间设为一小时前
setcookie("TestCookie", "", time() - 3600);
setcookie("TestCookie", "", time() - 3600, "/~rasmus/", ".utoronto.ca", 1);
?>
ログイン後にコピー

Cookie を削除する方法は、Cookie の有効期間を現在の有効期間よりも前に設定することです。 time

これは、ほぼすべての PHP プログラマーが行うことです。その後、PHP を初めて使用した友人が、プログラム内で Cookie の値を空に設定したいと言いましたが、Cookie は直接削除されました。当時の私の最初の反応は、信じられないということでしたので、テストしてみました。

setcookie("testcookie", &#39;&#39;);
print_r($_COOKIE);
ログイン後にコピー

結果は、$_COOKIE['testcookie'] だけでなく、$_COOKIE 配列全体が空でした。そこで、winsock を使用してパケットをキャプチャし、返された http ヘッダーを観察したところ、http ヘッダーが「Set-Cookie: testcookie=deleted; Expires=Mon, 18-Jun-2007 02:42:33 GMT」であることがわかりました。これは、「setcookie("testcookie ", '');」を意味し、確かに cookie testcookie を直接削除しますが、この状況については PHP マニュアルにはまったく説明がありません。

次のコードは、php5.20 Linux ソース パッケージの ext/standard/head.c の 99 行目近くにあります。ソースコード 表示 "if (value && value_len == 0)"、"value_len" が 0 の場合、"sprintf(cookie, "Set-Cookie: %s=deleted;expires=%s", name, dt) ; ”

は、Cookie を削除するための http ヘッダーをブラウザに送信します。

最後に、php で "setcookie($cookiename, '');" または "setcookie($cookiename, NULL);" を使用すると Cookie が削除されると結論付けることができます。

上記の内容は参考用です。

推奨チュートリアル:

PHP ビデオ チュートリアル

以上がPHPでCookieが削除できないの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート