How to Generate A Sitemap In Next.js?

17 minutes read

To generate a sitemap in Next.js, you can follow these steps:

  1. Install the required packages: First, you need to install the sitemap package. Open your terminal and run the following command: npm install sitemap --save.
  2. Create a sitemap generation page: In your Next.js project, create a new file called sitemap.xml.js inside the pages directory. This file will act as an API endpoint to generate the sitemap XML.
  3. Import dependencies: Inside the sitemap.xml.js file, import the necessary dependencies. Add the following lines at the top of the file:
1
2
3
4
import { createSitemap } from 'sitemap';
import fs from 'fs';
import path from 'path';
import { getAllPosts } from '../utils/posts'; // Assuming you have a util function to retrieve all your posts


  1. Generate the sitemap: Within the getServerSideProps function of the sitemap.xml.js file, generate the sitemap by retrieving all the necessary data. Here's an example:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
export async function getServerSideProps({ res }) {
  const posts = getAllPosts(); // Retrieve all posts from your util function
  
  const sitemap = createSitemap({
    hostname: 'https://yourwebsite.com', // Replace with your own website URL
    cacheTime: 600000, // Cache time for the generated XML (optional)
    urls: [
      { url: '/', changefreq: 'daily', priority: 0.7 },
      // Add more URL objects for each page you want to include in the sitemap
      ...posts.map((post) => ({
        url: `/posts/${post.slug}`,
        changefreq: 'weekly',
        priority: 0.5,
      })),
    ],
  });
  
  const sitemapPath = path.join(process.cwd(), 'public', 'sitemap.xml');
  fs.writeFileSync(sitemapPath, sitemap.toString());
  
  res.setHeader('Content-Type', 'text/xml');
  res.write(sitemap.toString());
  res.end();
  
  return {
    props: {},
  };
}


  1. Generate the sitemap: Once the file is saved, go to your terminal and run next build to generate the optimized production build of your Next.js project. Then, start the server using next start.
  2. Access the sitemap: You can now access the sitemap by visiting http://localhost:3000/sitemap.xml. This URL will dynamically generate the sitemap XML based on the data provided.


Remember to adjust the code based on your specific project structure and requirements.

Best SEO Books to Read in 2025

1
SEO 2024: Learn search engine optimization with smart internet marketing strategies

Rating is 5 out of 5

SEO 2024: Learn search engine optimization with smart internet marketing strategies

2
3 Months to No.1: The "No-Nonsense" SEO Playbook for Getting Your Website Found on Google

Rating is 4.9 out of 5

3 Months to No.1: The "No-Nonsense" SEO Playbook for Getting Your Website Found on Google

3
SEO For Dummies

Rating is 4.7 out of 5

SEO For Dummies

4
The Art of SEO: Mastering Search Engine Optimization

Rating is 4.6 out of 5

The Art of SEO: Mastering Search Engine Optimization

5
SEO Workbook: Search Engine Optimization Success in Seven Steps

Rating is 4.5 out of 5

SEO Workbook: Search Engine Optimization Success in Seven Steps

6
SEO in 2023: 101 of the world’s leading SEOs share their number 1, actionable tip for 2023

Rating is 4.4 out of 5

SEO in 2023: 101 of the world’s leading SEOs share their number 1, actionable tip for 2023


How to include images in a Next.js sitemap?

To include images in a sitemap for a Next.js application, you can use the next-sitemap package. Here's how you can set it up:

  1. Install the next-sitemap package in your Next.js project by running the following command in your terminal: npm install next-sitemap
  2. Create a next-sitemap.js file in the root of your project and add the following code to it: const withSitemap = require('next-sitemap'); module.exports = withSitemap({ sitemap: { hostname: 'https://example.com', // Replace with your application's hostname exclude: ['/admin'], // Add any routes you want to exclude from the sitemap pagesConfig: { '/': { priority: '1.0', // Set the priority for the homepage (optional) changefreq: 'daily', // Set the changefreq for the homepage (optional) }, // Add more pages with priority and changefreq settings as needed }, images: [], // Add your image URLs here }, });
  3. In your next.config.js file, add the following code to enable the sitemap generation: const withSitemap = require('./next-sitemap'); module.exports = withSitemap({ // Your existing Next.js configuration goes here // ... });
  4. Replace the empty array in the images option with the URLs of the images you want to include in the sitemap. For example: images: [ 'https://example.com/images/image1.jpg', 'https://example.com/images/image2.jpg', ], You can add as many image URLs as necessary.
  5. Run the Next.js development server or build command as usual. The sitemap with the included images will be generated automatically.
  6. The generated sitemap will be available at the URL /sitemap.xml of your application (e.g., https://example.com/sitemap.xml). You can check the sitemap to ensure that the images are included.


Note: Make sure to replace 'https://example.com' in the code with your actual application hostname, and provide the correct image URLs.


What is the recommended sitemap file naming convention in Next.js?

In Next.js, the recommended naming convention for the sitemap file is sitemap.xml.


How to handle multilingual routes in a Next.js sitemap?

To handle multilingual routes in a Next.js sitemap, you can follow these steps:

  1. Determine the languages supported by your website. For example, let's consider English (en) and Spanish (es).
  2. Create separate route files for each language in the pages directory. For example, pages/en/index.js and pages/es/index.js for the homepage, pages/en/about.js and pages/es/about.js for the about page, and so on.
  3. Install the next-sitemap package by running npm install next-sitemap or yarn add next-sitemap.
  4. Create a next-sitemap.js file in the root directory of your project.
  5. Import the defaultConfig from next-sitemap in next-sitemap.js.
  6. Extend defaultConfig by creating a custom configuration object.
  7. In the custom configuration object, specify the routes for each language by using the appropriate route files. For example:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
module.exports = {
  ...defaultConfig,
  i18n: true,
  locales: ['en', 'es'],
  defaultLocale: 'en',
  exclude: ['**/404'],
  pages: {
    en: {
      include: ['/', '/about'],
    },
    es: {
      include: ['/', '/acerca-de'],
    },
  },
};


  1. The i18n property should be set to true to enable the i18n configuration. The locales property specifies the supported languages. The defaultLocale property sets the fallback language in case the browser doesn't specify a preferred language.
  2. For each language, specify the routes to include in the include array. Make sure to use the correct language-specific routes.
  3. In your next.config.js file, add the following configuration to generate the sitemap:
1
2
3
4
5
6
7
8
module.exports = {
  //...
  env: {
    SITE_URL: 'https://your-website-url.com',
  },
  //...
  plugins: ['next-sitemap'],
};


  1. Replace 'https://your-website-url.com' with the URL of your website.
  2. Run the following command to generate the sitemap for all supported languages:
1
2
npm run build
npm run export


  1. You can find the generated sitemap files in the out directory, one for each language.
  2. Finally, submit each sitemap to search engines like Google, Bing, etc.


By following these steps, you can generate a multilingual sitemap for your Next.js website. Remember to adjust the routes and languages according to your specific requirements.

Best Web Hosting Providers in 2025

1
DigitalOcean

Rating is 5 out of 5

DigitalOcean

2
AWS

Rating is 5 out of 5

AWS

3
Vultr

Rating is 4.8 out of 5

Vultr

4
Cloudways

Rating is 4.7 out of 5

Cloudways


How to submit a Next.js sitemap to search engines?

To submit a Next.js sitemap to search engines, you can follow these steps:

  1. Generate the sitemap: Next.js does not have a built-in feature to generate a sitemap, so you will need to use a third-party library such as next-sitemap. Install this library using the following command: npm install next-sitemap
  2. Configure the sitemap: Create a next-sitemap.js file in the root directory of your project and configure the sitemap. You can specify the URLs to include, set priority and change frequency for each page, and more. Here's an example configuration: module.exports = { siteUrl: 'https://example.com', generateRobotsTxt: true, sitemapSize: 7000, exclude: ['/admin/**'], robotsTxtOptions: { additionalSitemaps: [ 'https://example.com/another-sitemap.xml', ], }, };
  3. Generate the sitemap: Add a script to your package.json file to generate the sitemap. Open package.json and modify the "scripts" section as follows: "scripts": { "build": "next build", "start": "next start", "generate-sitemap": "npx next-sitemap" }
  4. Generate the sitemap file: Run the following command to generate the sitemap file: npm run generate-sitemap
  5. Submit the sitemap to search engines: Google: Visit the Google Search Console (https://search.google.com/search-console) and select your website. Go to the "Sitemaps" section and click on "Add a new sitemap". Enter the URL of your sitemap (e.g., https://example.com/sitemap.xml) and submit it. Bing: Sign in to Bing Webmaster Tools (https://www.bing.com/webmasters/) and select your website. Go to the "Sitemaps" section and click on "Submit a Sitemap". Enter the URL of your sitemap and submit it. Other search engines: Each search engine may have its own process for submitting a sitemap. Refer to their respective documentation for more information.


Once you have submitted the sitemap, search engines will periodically crawl your website and update their index accordingly.


What are the best practices for generating a sitemap in Next.js?

There are several best practices for generating a sitemap in Next.js:

  1. Use a dedicated package: Next.js does not include a built-in sitemap generation feature, so you'll need to use a third-party package. A popular choice is the next-sitemap package, which provides a simple and efficient way to generate a sitemap.
  2. Install and configure the package: Start by installing the next-sitemap package using npm or yarn. Once installed, create a next-sitemap.js file in the root of your Next.js project and configure it based on your specific requirements. The package documentation provides detailed instructions on how to set up the configuration file.
  3. Use dynamic route generation: Next.js offers dynamic route generation using the getServerSideProps function. Leverage this feature to dynamically generate your sitemap based on your website's pages and data. You can fetch any necessary data and build your sitemap structure within this function.
  4. Exclude unnecessary routes: Some pages or routes may not be relevant for inclusion in the sitemap, such as private or administrative pages. Make sure to exclude these routes from the sitemap configuration to keep it focused on the main content.
  5. Include relevant metadata: Each entry in your sitemap should include important metadata such as the URL, last modified date, change frequency, and priority. This metadata helps search engines understand the importance of each page and how frequently it is updated.
  6. Generate and deploy the sitemap: Once you have configured your sitemap, use the next-sitemap package to generate the actual sitemap file. You can do this by running a command, such as yarn next-sitemap or npm run next-sitemap, which will generate the sitemap file in the public directory of your Next.js project. Finally, make sure to include the sitemap file in your deployment process so that search engines can discover and use it.
  7. Submit the sitemap to search engines: To maximize the visibility of your website's pages, submit the generated sitemap to search engines like Google, Bing, and others. Each search engine provides a specific process for submitting sitemaps, so make sure to follow their documentation.


Remember to keep your sitemap updated whenever you add or remove pages from your Next.js project. Regularly updating and submitting the sitemap helps search engines discover and index your website effectively.


How to customize the appearance of a Next.js sitemap for better user experience?

Customizing the appearance of a Next.js sitemap can greatly improve the user experience. Here are some steps you can follow:

  1. Define a clear structure: Plan out the structure of your sitemap beforehand to ensure it is user-friendly. Organize the pages and sections in a logical manner that is easy to navigate.
  2. Use descriptive page titles: Provide meaningful and descriptive page titles for each entry in the sitemap. This helps users understand what each page is about and encourages them to click on it.
  3. Add relevant meta descriptions: Include meta descriptions for each page in the sitemap. These short summaries will appear in search engine results and can entice users to visit your website.
  4. Use user-friendly URLs: Ensure that the URLs in your sitemap are user-friendly and descriptive. This makes it easier for users to understand what the page is about before even visiting it.
  5. Include visual elements: Consider adding visual elements such as icons or images to the sitemap to make it more visually appealing. These icons can represent different sections or types of content, making it easier for users to navigate the sitemap.
  6. Provide clear navigation: Include a clear and consistent navigation menu in your sitemap. This helps users easily find their way around the website and access different sections or pages.
  7. Use formatting and styling: Apply consistent formatting and styling throughout the sitemap to make it visually appealing and easy to read. Use headings, subheadings, and bullet points to break up the content and make it more scannable.
  8. Optimize for mobile: Ensure that the sitemap is responsive and mobile-friendly. Many users access websites from their mobile devices, so it's important to provide a seamless experience across different screen sizes.
  9. Test and iterate: Regularly test your sitemap with users to gather feedback and make improvements. User testing can help identify any usability issues and provide valuable insights for enhancing the user experience.


By following these steps, you can customize the appearance of your Next.js sitemap to provide a better user experience and improve engagement with your website.


How to add custom routes to a Next.js sitemap?

To add custom routes to a Next.js sitemap, you can follow these steps:

  1. Install the next-sitemap package by running the following command in your terminal: npm install next-sitemap
  2. Create a next-sitemap.js file in the root of your Next.js project.
  3. In the next-sitemap.js file, import the necessary packages: const SitemapGenerator = require('next-sitemap'); const fs = require('fs');
  4. Define your custom routes as an array of objects. Each object should have a route property to specify the route and other optional properties like priority, changefreq, etc. For example: const routes = [ { route: '/', priority: 1, changefreq: 'daily', }, { route: '/about', priority: 0.8, changefreq: 'weekly', }, // Add more custom routes here ];
  5. Generate the sitemap using the SitemapGenerator class. Pass in the routes array and other configuration options as needed. For example: const generator = new SitemapGenerator( 'https://example.com', routes, // Other options like `gzip`, `exclude`, etc. );
  6. Call the transform method on the generator instance to transform the custom routes into a valid XML sitemap. For example: const sitemap = generator.transform();
  7. Write the generated sitemap to a file. You can use the fs.writeFile method for this. For example: fs.writeFileSync('./public/sitemap.xml', sitemap);
  8. Add a script in your package.json file to run the sitemap generation command. For example: "scripts": { "generate-sitemap": "node next-sitemap.js" }
  9. Run the sitemap generation command by running the following command in your terminal: npm run generate-sitemap
  10. The sitemap will be generated and saved as ./public/sitemap.xml in your Next.js project's folder.


Make sure to include the ./public/sitemap.xml file in your server-side rendering (SSR) routes so that search engines can discover it.

Facebook Twitter LinkedIn Telegram Whatsapp Pocket

Related Posts:

To generate a sitemap in Gatsby, you can follow these steps:Install the necessary packages: First, install the gatsby-plugin-sitemap package by running the following command in your terminal: npm install gatsby-plugin-sitemap Configure the plugin: Open your ga...
To generate a sitemap in Opencart, follow these steps:Log in to the Opencart administration panel.Navigate to the "Extensions" menu and click on "Feed."From the available options, locate and click on "Google Sitemap."On the Google Sitem...
To remove a sitemap from the Google Search Console, you can follow these steps:Go to the Google Search Console website and sign in with your Google account.Select the website property for which you want to remove the sitemap.On the left-hand side menu, click o...