In Yoast SEO 14.0 we introduced a REST API endpoint that'll give you all the metadata you need for a specific URL. This will make it very easy for headless WordPress sites to use Yoast SEO for all their SEO meta output.
There are two ways of using this: through its inclusion in the normal WP REST API responses and through our own endpoint.
Inclusion in WP REST API responses
When you're retrieving a post like so:
http://example.com/wp-json/wp/v2/posts?slug=hello-world, you'll receive a normal WP REST API response, with an additional field:
yoast_head. This additional field will contain a blob with all the necessary meta tags for that page. This works for the
tags and all custom post types and custom taxonomies.
For post type archives, when you query the types endpoint the meta is included there, also on the
yoast_head field. If it is not there, the post type does not have a post type archive enabled.
Yoast SEO REST API syntax
The syntax is very simple, you just
/wp-json/yoast/v1/get_head?url= with the proper URL, for example:
This will return the following:
head contains the complete meta output for the page. This means the Yoast SEO REST API output contains everything:
- The title
- The meta description, if you have one
- Robots meta tags
- The canonical URL
- Our Schema output
- OpenGraph meta data
- Twitter meta data
For an example, see this output for a post here on developer.yoast.com.
Can I use this API to update data as well?
The Yoast REST API doesn't currently supports
PUT calls to update the data. Patches adding this functionality are welcome though.
The API returns 404 for an existing page?
status is not
200 but you're certain the page exists, you'll need to make sure your site is completely indexed. Just hitting save on the backend should save the post or page to our Indexables database. Note that Yoast SEO will return a head for other statuses too, so you can use the output on, for instance,
If you have a notice in your site's admin about indexing your site: please run that index process if you intend to rely on this API.
I don't want this API on my site!
You can easily disable this API by going to SEO - General - Features and disabling the feature toggle.