This post was published 9 years ago

There's a chance things are out of date or no longer reflect my views today

Setting a cookie with Wordpress

At one point, I was relying on JavaScript for setting the cookie for my critical path CSS. The issue with that is when JavaScript isn’t available the cookie will not be set. Not a huge deal as the website, would still function.When it comes to Wordpress, it’s not as straight forward as using setcookie in your header.php file or another less than ideal location. In this post I will show you how to set a cookie with Wordpress and use it in your code. The method is very similar to the JavaScript method, with a focus on PHP and Wordpress.

2,438 views

Setting a cookie with Wordpress (featured image)

At one point, I was relying on JavaScript for setting the cookie for my critical path CSS. The issue with that is when JavaScript isn’t available the cookie will not be set. Not a huge deal as the website, would still function.

When it comes to Wordpress, it’s not as straight forward as using setcookie in your header.php file or another less than ideal location. In this post I will show you how to set a cookie with Wordpress and use it in your code. The method is very similar to the JavaScript method, with a focus on PHP and Wordpress.

Using setcookie() in PHP

setcookie takes up to seven parameters, although we will be using four. These are name, value, expire and path, in that order.

setcookie('full-css', true, time() + (86400 * 28), '/');

First parameter ‘full-css’

This is the name parameter, it can be anything. You’ll want it to be something memorable and descriptive though.

Second parameter ‘true’

The value parameter, can be anything also. It’s not too important as we don’t rely on it in code anywhere. It’s just necessary to have a value.

Third parameter ’time() + (86400 * 28)’

The expire parameter, can be any value in seconds. You should set it to be long enough. 28 days is the equivalent, it is currently.

Fourth parameter ‘/‘

The setcookie documentation says the path parameter “If set to ’/’, the cookie will be available within the entire domain.” By default it’s empty, so we need to set it across the domain.

Using the init hook in Wordpress

To set a cookie it’s done by adding a call to the init hook. This allows the cookie to be set at the very earliest point.

add_action( 'init', ‘full_css_cookie' );

function full_css_cookie()
{
  setcookie('full-css', true, time() + (86400 * 21), '/');
}

In your functions.php, add these lines of code.

To check whether a cookie exists we must use isset. It checks if the cookie is set and isn’t null.

<?php if ( isset($_COOKIE['full-css']) ) : ?>
<?php else : ?>
<?php endif; ?>

Viewing your cookies

Finally, you should always test everything is working. The way that I check if a cookie is being set is by opening developer tools. It depends on what browser you use, but they all share many similarities. So it should be familiar if you’re switching between browsers.

Chrome & Safari

In Chrome and Safari you can find cookies under the ‘Resources’ tab.

If you need to delete a cookie you can highlight it and press backspace.

In Firefox

In Firefox it’s a little trickier. You need to open developer tools, go into ‘Toolbox Options’ it’s the cog icon third from the right. Then under the heading ‘Default Firefox Developer Tools’ you will find a checkbox for storage. Enable that and the storage tab will be available.

Pop into settings

Firefox developer tools settings

Then into storage to find cookies

Now the storage tab is available, it shares similarities of Safari and Chrome
View on Github