php setcookie メソッドで Cookie を削除します: 1. PHP サンプル ファイルを作成します; 2. 「setcookie("TestCookie", "", time() - 3600);」メソッドを通じて Cookie を削除します。
この記事の動作環境: Windows 7 システム、PHP バージョン 7.1、DELL G3 コンピューター
php setcookie 削除方法クッキー?
php Cookie の削除方法の詳細な説明:
まず、関連する Cookie の仕組みを見てみましょう。
コードは次のとおりです:
bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure]]]]] )
Cookie を削除するには、ブラウザの削除メカニズムをトリガーするために、その有効期限が過去であることを確認する必要があります。
次の例は、設定したばかりの Cookie を削除する方法を示しています:
コードは次のとおりです:
<?php //将过期时间设为一小时前 setcookie("TestCookie", "", time() - 3600); setcookie("TestCookie", "", time() - 3600, "/~rasmus/", ".utoronto.ca", 1); ?>
Cookie を削除する方法は、 Cookie の有効期間を現在の時点までは、ほぼすべての PHP プログラマーがこれを行っていました。
その後、PHP を初めて使用した友人が、プログラム内で Cookie の値を空に設定したいと言いましたが、Cookie は直接削除されてしまいました。当時の私の最初の反応は、信じられないということでしたので、テストしてみました
:
コードは次のとおりです:
setcookie("testcookie", ''); print_r($_COOKIE);
結果は、 $_COOKIE 配列全体が空であり、$_COOKIE['testcookie'] だけが空ではありません。そこで、winsock を使用してパケットをキャプチャし、返された http ヘッダーを観察したところ、http ヘッダーが「Set-Cookie: testcookie=deleted; Expires=Mon, 18-Jun-2007 02:42:33 GMT」であることがわかりました。これは、「setcookie("testcookie ", '');」を意味し、確かに cookie testcookie を直接削除しますが、この状況については PHP マニュアルにはまったく説明がありません。
ようやく PHP のソースコードを読んで、ようやく真実が分かりました(これはオープンソースの利点です。不明な裏話がある場合は、ソースコードを直接確認してください)。
次のコードは、php5.20 Linux ソース パッケージの ext/standard/head.c の 99 行目近くにあります:
コードは次のとおりです:
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); } }
ソースコード内で明確にする 「value_len」が0の場合、「if (value && value_len == 0)」と明示的に表示する、「sprintf(cookie, "Set-Cookie: %s=deleted;expires=%s", name, dt); 」は、Cookie を削除するための http ヘッダーをブラウザに送信します。
最終的に結論を導き出すことができます。php で "setcookie($cookiename, '');" または "setcookie($cookiename, NULL);" を使用すると Cookie が削除されますが、もちろんそのようなマニュアルはありません。 。
とても簡単ではありませんか? 場合によっては、php ソース コードを注意深く読む必要があります。
推奨学習: 「PHP ビデオ チュートリアル 」
以上がPHP setcookieを使用してCookieを削除する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。