1 - Вы можете проверить наличие файлов cookie и выполнить переадресацию с помощью ловушек, которые вызываются перед любым выводом, таким как ловушка 'init':
<?php
// Hook the function "redirect()" on to the "init" action
add_action('init', 'redirect');
// redirect() may redirect the user depending on the cookies he has
function redirect(){
/* CODE */
}
?>
2 - Лучший способ установить куки - это использовать ловушку init так:
<?php
add_action('init', 'my_setcookie');
// my_setcookie() set the cookie on the domain and directory WP is installed on
function my_setcookie(){
$path = parse_url(get_option('siteurl'), PHP_URL_PATH);
$host = parse_url(get_option('siteurl'), PHP_URL_HOST);
$expiry = strtotime('+1 month');
setcookie('my_cookie_name_1', 'my_cookie_value_1', $expiry, $path, $host);
/* more cookies */
setcookie('my_cookie_name_2', 'my_cookie_value_2', $expiry, $path, $host);
}
?>
Это более последовательно, если у вас есть блог на www.example.com/blog , то куки не будут доступны на
- www.example.com
- www.example.com/store
- example.com
- www2.example.com
- ...
Обновить
вы также должны иметь возможность использовать константы COOKIE_PATH и COOKIEDOMAIN вместо того, чтобы самостоятельно их выяснять, что я только что заметил в ответе Андре Р Коля - drzaus