How to Redirect a Route After Renaming It
Photo by Nick Fewings on Unsplash
Introductionβ
Renaming a route in your web application is a common task, but itβs crucial to handle it correctly to avoid breaking links and negatively impacting your SEO. Redirecting the old route to the new one ensures a seamless user experience and maintains your site's search engine rankings.
In this blog post, weβll guide you through the steps to set up a redirection after renaming one of your pages.
Why Redirecting is Importantβ
Redirecting an old route to a new one is essential for several reasons:
-
SEO: Search engines index your site's URLs. If you change a route without setting up a redirection, search engines might treat it as a broken link, which can hurt your rankings.
-
User Experience: Users who have bookmarked the old URL or found it through search engines or external links will face a 404 error if the route is changed without a redirection.
-
Preserving Traffic: Redirecting helps in preserving the traffic and link equity that the old URL had built over time.
Why Not Just JavaScriptβ
While you might consider using JavaScript to handle redirects on the client side, this approach has several significant drawbacks:
-
SEO Limitations: Search engines may not execute JavaScript redirects as reliably as server-side redirects. This can lead to indexing issues and lower search engine rankings.
-
Performance: Client-side redirects can cause a delay because the browser must load the initial page before executing the redirect, resulting in a slower user experience.
-
Accessibility: Not all users have JavaScript enabled in their browsers. Client-side redirects won't work for these users, leading to broken links and a poor user experience.
-
Consistency: Redirects handled by your smart contract are processed before the page is sent to the browser, ensuring a more consistent and immediate redirection experience for all users.
For these reasons, it's best to handle redirects through configurations, ensuring they are fast, reliable, and SEO-friendly.
Step-by-Step Guideβ
1. Rename the Routeβ
First, rename the route in your code. This might involve changing the path in your routing configuration file, as well as updating any references to this route throughout your application.
2. Deploy the Updateβ
Deploy your updated website using GitHub Actions or by running the juno deploy
command in your terminal. This step ensures that your changes are live and the new route is accessible.
3. Set Up the Redirection in Juno Configβ
Next, configure the redirection in your Juno configuration. This involves specifying the old route and the new route so that requests to the old route are redirected to the new one.
For example, we recently renamed https://juno.build/docs/add-juno-to-an-app/install-the-sdk-and-initialize-juno to https://juno.build/docs/add-juno-to-an-app/setup. Therefore, we added the following redirection in our juno.config.ts file:
import { defineConfig } from "@junobuild/config";
export default defineConfig({
satellite: {
id: "ucnx3-aqaaa-aaaal-ab3ea-cai",
source: "build",
storage: {
redirects: [
{
source:
"/docs/add-juno-to-an-app/install-the-sdk-and-initialize-juno",
location: "/docs/add-juno-to-an-app/setup",
code: 301
}
]
}
},
orbiter: {
id: "3iier-sqaaa-aaaal-aczaa-cai"
}
});
Note that we set up a 301 status code to indicate that the requested resource has been permanently moved to the new URL.
4. Clear the Previous Routeβ
Before applying the new configuration, clear the old route using the juno clear -f
path command.
juno clear -f /path/to/old/route
For example, using the same example as in the previous step, we ran the following command to remove the deprecated route:
juno clear -f /docs/add-juno-to-an-app/install-the-sdk-and-initialize-juno
We remove the old route because when you deploy, it always writes (updates or adds) new resources, meaning the page that was removed is still available. This is done to avoid breaking backlinks, similar to why you want to set up a redirect. By clearing the old route, we also ensure the configuration can be set up correctly.
Note that you can also delete all assets with
juno clear
and redeploy withjuno deploy
or clear and deploy withjuno deploy --clear
. However, removing a single asset requires fewer resources and is therefore less costly.
5. Apply the Configβ
Finally, apply the new configuration with the juno config
command. This updates the routing settings to include the redirection.
juno config
Tada! Your old route now seamlessly redirects to the new one, and your website continues to run smoothly. π₯³
Conclusionβ
By following these steps, you can successfully rename a route and set up a redirection in Juno. This approach helps maintain your SEO rankings, provides a better user experience, and ensures that your traffic remains intact.
π
Stay connected with Juno by following us on X/Twitter.
Reach out on Discord or OpenChat for any questions.
βοΈβοΈβοΈ stars are also much appreciated: visit the GitHub repo and show your support!