setcookie
(PHP 4, PHP 5)
setcookie — クッキーを送信する
説明
bool setcookie
( string $name
[, string $value
[, int $expire = 0
[, string $path
[, string $domain
[, bool $secure = false
[, bool $httponly = false
]]]]]] )
一度クッキーが送信されると、次のページのロードからは
$_COOKIE や
$HTTP_COOKIE_VARS 配列によってクッキーにアクセスできます。
$_COOKIE のような
スーパーグローバル は
PHP 4.1.0 以降で有効となることに注意してください。
クッキーの値は $_REQUEST
配列からもアクセスできます。
パラメータ
name
以外の全ての引数はオプションです。
全ての引数に関して引数の指定をスキップするために空文字列
("") とすることが可能です。
expire
および secure
は数値なので、空文字列でスキップすることはできません。代わりにゼロ
(0) を使用してください。
setcookie() 関数の各引数が
どのように作用するかを知るには
» Netscape cookie specification
を参照ください。
-
name
-
クッキーの名前。
-
value
-
クッキーの値。この値はクライアントのコンピュータに保存されますので、
重要な情報は格納しないでください。
name
が 'cookiename' だとすると、
その値は $_COOKIE['cookiename'] で取得することができます。
-
expire
-
クッキーの有効期限。これは Unix タイムスタンプなので
Epoch(1970 年 1 月 1 日)からの経過秒数となります。
time() または
mktime() 関数により
返された現在のUNIX標準時に、期限としたい必要な秒数を加算したものを
利用することができるでしょう。
time()+60*60*24*30
はクッキーの有効期限を 30 日後にセットします。
0 を設定したり省略したりした場合は、クッキーはセッションの最後
(つまりブラウザを閉じるとき) が有効期限となります。
注意:
expire
パラメータには、Wdy, DD-Mon-YYYY
HH:MM:SS GMT といった形式ではなく Unix
タイムスタンプを渡していることにお気づきでしょうか。
これは、PHP の内部で自動的に変換を行っているからです。
expire
は、クライアントの時刻と比較されます。
サーバの時刻との比較ではありません。
-
path
-
サーバ上での、クッキーを有効としたいパス
'/' をセットすると、クッキーは
domain
配下の全てで有効となります。
'/foo/' をセットすると、クッキーは
/foo/ ディレクトリとそのサブディレクトリ配下
(例えば /foo/bar/) で有効となります。
デフォルト値は、クッキーがセットされたときのカレントディレクトリです。
-
domain
-
クッキーが有効なドメイン。
exapmle.com の全てのサブドメインでクッキーを有効とするには
'.example.com' をセットします。
. は必須ではありませんが、
多くのブラウザにおいて互換性があります。
www.example.com にセットすると、
クッキーはwww
サブドメインにおいてのみ有効となります。
末尾のマッチングについての詳細は » 仕様
をご覧ください。
-
secure
-
クライアントからのセキュアな HTTPS 接続の場合にのみクッキーが送信されるようにします。
TRUE を設定すると、セキュアな接続が存在する場合にのみクッキーを
設定します。デフォルトは FALSE です。
サーバ側では、このようにセキュアな接続の場合にのみクッキーを送信するという処理は
プログラマの責任で行うことになります
(たとえば $_SERVER["HTTPS"] の内容を使用します)。
-
httponly
-
TRUE を設定すると、HTTP を通してのみクッキーにアクセスできるようになります。
つまり、JavaScript のようなスクリプト言語からはアクセスできなくなるということです。
この設定を使用すると、XSS 攻撃によって ID を盗まれる危険性を減らせます
(が、すべてのブラウザがこの設定をサポートしているというわけではありません)。
PHP 5.2.0 で追加されました。
TRUE あるいは FALSE で指定します。
返り値
もしもこの関数をコールする前に何らかの出力がある場合には、
setcookie() は失敗し FALSE を返します。
setcookie() が正常に実行されると、TRUE を返します。
この関数では、ユーザがクッキーを受け入れたかどうかを判断することはできません。
例
以下はクッキーを送信する例です。
例1 setcookie() での送信の例
<?php
$value = 'something from somewhere';
setcookie("TestCookie", $value);
setcookie("TestCookie", $value, time()+3600); /* 有効期限は一時間です */
setcookie("TestCookie", $value, time()+3600, "/~rasmus/", ".example.com", 1);
?>
クッキーの value の部分は、クッキーの送信を行う際に自動的に
URL エンコードされ、またクッキーを受信した際は、自動的にデコード
されてクッキー名と同じ名前の変数に格納されることに注意してください。
この挙動が気に入らない場合、もし PHP 5 を使用しているなら
代わりに setrawcookie() を使ってください。
スクリプト内部で TestCookie の内容を見たい場合は、
以下のいずれかの例を使用します。
例2 setcookie() による削除の例
クッキーを削除する場合には、ブラウザの削除機構を起動するために
必ず有効期限を過去に設定する必要があります。
次に、先ほどの例で送信したクッキーを削除する例を示します。
<?php
// 有効期限を一時間前に設定します
setcookie ("TestCookie", "", time() - 3600);
setcookie ("TestCookie", "", time() - 3600, "/~rasmus/", ".example.com", 1);
?>
例3 setcookie() と配列
クッキー名で配列を記述することにより、クッキーの配列を設定することも可能です。
これにより配列要素と同数のクッキーを設定されますが、
クッキーがスクリプトに受信された際に、
値はクッキー名を有する配列に置きかえられます。
<?php
// クッキーを設定します
setcookie("cookie[three]", "cookiethree");
setcookie("cookie[two]", "cookietwo");
setcookie("cookie[one]", "cookieone");
// ページを再読み込みした後に、表示します
if (isset($_COOKIE['cookie'])) {
foreach ($_COOKIE['cookie'] as $name => $value) {
echo "$name : $value <br />\n";
}
}
?>
three : cookiethree
two : cookietwo
one : cookieone
注意
注意:
この関数をコールする前でも出力できるように、
スクリプトの全ての出力をサーバ内にバッファリングさせることができます。
そのためには、ob_start() や ob_end_flush()
を使用するか、あるいは php.ini やサーバ設定ファイルの output_buffering
を使用します。
注意:
PHPの register_globals
ディレクティブが on になっている場合、
クッキーは変数にも登録されています。
以下の例では、$TestCookie 変数が存在します。
$_COOKIE の使用することを推奨します。
陥りやすい失敗
-
クッキーは、クッキーを有効にするために次にページをロードするまで
アクセスすることができません。クッキーが正常にセットされたか
テストするために、クッキーの有効期限が切れる前に次のページを
ロードしてクッキーをチェックしてください。
有効期限は expire
引数でセットされます。
クッキーの利用についてデバッグするのに良い方法は
print_r($_COOKIE); をコールすることです。
-
クッキーは設定されたものと同じパラメータで削除する必要があります。
値が空文字列あるいは FALSE で、その他の全ての引数が前に setcookie
をコールした時と同じである場合に、指定された名前のクッキーが
リモートクライアント上から削除されます。
内部的な動作として、これは値を 'deleted' に変更した上で有効期限を
1 年前に設定しています。
-
クッキーの値として FALSE を設定すると、クッキーを削除しようとします。
そのため、boolean 値は使用できません。その代わりとして、
FALSE ではなく 0、そして TRUE
ではなく 1 を使用します。
-
クッキー名で配列を記述することにより、
クッキーの配列を設定することも可能ですが、複数のクッキー
がユーザーのシステム上に保存されることになります。
explode() を使用して
ひとつのクッキー上に複数の名前と値をセットすることも
考慮してください。serialize()
の使用はセキュリティーホールになり得るため、
この目的のために使用することはお勧めしません。
setcookie() を複数回コールした場合は、コールした順番で実行されます。