How to fix "//*" canonical error in GatsbyJS
data:image/s3,"s3://crabby-images/b6283/b6283d6dab3a9d5fd6ceacdf08c7e1602be03f81" alt="Oscar de la Hera Gomez"
data:image/s3,"s3://crabby-images/29ac1/29ac1322fed74202f424c091776b9d20cbd0b8f7" alt="A flower that represents Gatsby with the text "Fix "//*" canonical error" beneath it."
Gatsby creates a "/*" canonical URL when using the "path" from a programmatically created page. Use the page URI to remove this error.
data:image/s3,"s3://crabby-images/a69b7/a69b76eb1a0d0e7069d984f1d10bbdcd955faf62" alt="A screenshot of Chrome showing how the canonical url of a page has a "//*" in it."
The following article addresses the issue above by which Gatsby creates pages with a "/*" in the canonical URL instead of the correct URI.
data:image/s3,"s3://crabby-images/99243/9924371bc74719a6984bece1a04ca2f62d22c98e" alt="A screenshot of VSCode highlighting the path that is passed into a programatically created page in Gatsby. Highlighted is also how we use it to generate the SEO for the page, through the react helmet NPM package."
This occurs when an individual programmatically create pages using the "gatsby-node." script and subsequently uses the "path" that is produced by the "gatsby-node" script to create the canonical URL.
To avoid it follow the steps outlined below.
Step One: Remove the Path
data:image/s3,"s3://crabby-images/0af79/0af79c831f66f5d9a113889c5cc4b344a1e69229" alt="A screenshot of VSCode highlighting how we removed the "path" from the props of a page that was created programmatically using the gatsby-node script."
In all the templates that use the path, remove the path from the props.
Step Two: Add the URI to the GraphQL Query
data:image/s3,"s3://crabby-images/04c6e/04c6e50f16630ce0150785b31e79fc2ae335bf03" alt="A screenshot of VSCode highlighting how we added a URI to a GraphQL query."
Add the uri to the GraphQL query and associated typescript types.
Step Three: Update the Canonical URL
data:image/s3,"s3://crabby-images/47f4b/47f4b22b0a1c924363bc4b1f82b51df1ae122517" alt="A screenshot of VSCode showing how we pass the URI to the metadata of a page."
Wherever you had previously used the path, use the uri.
Please note this might require you updating the logic.
Step Four: Test
data:image/s3,"s3://crabby-images/9646c/9646c9bd2cb04d3f4501737c043d5ab6dda792c3" alt="A screenshot of Chrome highlighting that the canonical url has been fixed."
Build, deploy the website and confirm the canonical error has been resolved.
Looking to learn more about ReactJS, GatsbyJS or SEO ?
Search our blog to find educational content on learning SEO as well as how to use ReactJS and GatsbyJS.