質問に正確に答えるには、関数を作成する場合
<?php
function cookies_are_enabled() {
setcookie('enabled', 'enabled');
return $_COOKIE['enabled'] === 'enabled';
}
?>
次に、コードに次のものがあります。
<?php
if (cookies_are_enabled()) {
/* Cookies related code goes here */
/* Create PHP cookie, read cookies etc */
} else {
/* Do something else */
}
?>
更新:コメントで指摘されているように。これは直接には機能しません。setcookie PHPページから(私の強調):
Cookie が設定されると、次のページ読み込み時に $_COOKIE または $HTTP_COOKIE_VARS 配列を使用してアクセスできます。$_COOKIE などのスーパーグローバルは、PHP 4.1.0 で使用できるようになったことに注意してください。Cookie 値も $_REQUEST に存在します。
あなたが setcookie を信頼できないことを考えると、私が考えることができる最善の方法は、リダイレクトを強制することです。
<?php
function cookies_are_enabled() {
// if first page load
// set cookie and redirect
// if redirected check the cookie
if (isset($_GET['cookie_check'])) {
return $_COOKIE['enabled'] === 'enabled';
} else {
setcookie('enabled', 'enabled');
if (empty($_SERVER['QUERY_STRING'])) {
$url = $_SERVER['PHP_SELF'].'?cookie_check=1';
} else {
$url = $_SERVER['PHP_SELF'].'?'.$_SERVER['QUERY_STRING'].'&cookie_check=1';
}
exit(header("Location: $url"));
}
}
if (cookies_are_enabled()) {
/* Cookies related code goes here */
/* Create PHP cookie, read cookies etc */
$message = 'cookies are enabled';
} else {
/* Do something else */
$message = 'cookies are <strong>not</strong> enabled';
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Cookies!</title>
</head>
<body>
<p><?php echo $message; ?></p>
</body>
</html>