ホームページ > バックエンド開発 > PHPチュートリアル > PHPでCookieインスタンスを削除する方法を詳しく解説

PHPでCookieインスタンスを削除する方法を詳しく解説

小云云
リリース: 2023-03-21 06:52:01
オリジナル
1258 人が閲覧しました

この記事では主に、PHP で Cookie インスタンスを削除する方法について詳しく説明します。まず、関連する Cookie のメカニズムを見てみましょう。皆さんのお役に立つことを願っています。

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

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

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

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

Cookie を削除する方法は、Cookie の有効期間を現在時刻より前に設定することです。これは、ほとんどすべての PHP プログラマーが行っていることです。 。

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

setcookie("testcookie", '');
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 マニュアルにはまったく説明がありません。

最後にphpのソースコードを読んで、ついに真実を見つけました(これはオープンソースの利点です。内部の話について不明な点がある場合は、ソースコードを直接確認してください)。

次のようにコードをコピーします:

if (value && value_len == 0) {
    /* 
     * MSIE doesn't delete a cookie when you set it to a null value
     * so in order to force cookies to be deleted, even on MSIE, we
     * pick an expiry date 1 year and 1 second in the past
     */
    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=deleted; expires=%s", name, dt);
    efree(dt);
} else {
    sprintf(cookie, "Set-Cookie: %s=%s", name, value ? encoded_value : "");
    if (expires > 0) {
        strcat(cookie, "; expires=");
        dt = php_format_date("D, d-M-Y H:i:s T", sizeof("D, d-M-Y H:i:s T")-1, expires, 0 TSRMLS_CC);
        strcat(cookie, dt);
        efree(dt);
    }
}
ログイン後にコピー
ソースコードは、「if (value && value_len == 0)」を明確に示しています。「value_len」が 0 の場合、「sprintf(cookie, "Set-Cookie: %s= selected; expires=%s", name, dt);" は、Cookie を削除するための http ヘッダーをブラウザに送信します。

最終的に、php で "setcookie($cookiename, '');" または "setcookie($cookiename, NULL);" を使用すると Cookie が削除されると結論付けることができますが、もちろんそのようなマニュアルはありません。

とても単純ではないでしょうか? 場合によっては、php のソース コードを注意深く読む必要があります。

関連する推奨事項:

Cookieの取得とCookieの削除のためのJavaScriptの詳細な説明

PHPでCookieを削除する方法

PHPのCookieクラス(Cookie値の設定、取得、削除)

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

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