How To Create Dynamic XML Sitemap In Laravel 9

Websolutionstuff | Jun-08-2022 | Categories : Laravel

In this article, we will see how to create a dynamic XML sitemap in laravel 9. As we know sitemap is a very important part of SEO. The sitemap is a list of pages of a website within a single domain. The sitemap is a blueprint of your website that can help to search engines find, crawl, and index all of your website's content.

So, let's see how to create a dynamic XML sitemap in laravel 9, laravel 9 sitemap dynamic generate, laravel 9 generate a sitemap XML file, how to create XML sitemap in laravel 9, laravel 9 sitemap dynamic generate, sitemap generator in laravel 9.

Step 1: Install Package

In this step, we will install watson/sitemap package using the below command.

composer require watson/sitemap

 

 

Step 2: Configure Package

To publish the configuration file for the sitemap package using the below command.

php artisan config:publish watson/sitemap

php artisan vendor:publish --provider="Watson\Sitemap\SitemapServiceProvider"

Here, you need to add tags for each item in your sitemap using Sitemap::addTag($location, $lastModified, $changeFrequency, $priority). And we can return the sitemap with Sitemap::renderSitemap().

$lastModified variable will be parsed and converted to the right format for the sitemap.

If you want to get raw XML then simply call Sitemap::xml()

Example:

namespace App\Http\Controllers;

use Post;
use Sitemap;

class SitemapsController extends Controller
{
    public function posts()
    {
        $posts = Post::all();

        foreach ($posts as $post) {
            Sitemap::addTag(route('posts.show', $post), $post->updated_at, 'daily', '0.6');
        }

        return Sitemap::render();
    }
}

 

 

Image Sitemap:

Parameters :  $tag->addImage($location, $caption, $geoLocation, $title, $licenceUrl).

namespace App\Http\Controllers;

use Page;
use Sitemap;

class SitemapsController extends Controller
{
    public function pages()
    {
        $pages = Page::all();

        foreach ($pages as $page) {
            $tag = Sitemap::addTag(route('pages.show', $page), $page->updated_at, 'daily', '0.8');

            foreach ($page->images as $image) {
                $tag->addImage($image->url, $image->caption);
            }
        }

        return Sitemap::render();
    }
}

 


You might also like :

Recommended Post
Featured Post
How To Preview Image Before Upload In jQuery
How To Preview Image Before Up...

In this article, we will see how to preview an image before uploading it in jquery. You can use the JavaScript...

Read More

Jul-15-2022

How To Encrypt And Decrypt String In Laravel 9
How To Encrypt And Decrypt Str...

In this article, we will see how to encrypt and decrypt a string in laravel 9. Using crypt helper, As we all know larave...

Read More

Mar-09-2022

Laravel 11 Socialite Login With GitHub Account
Laravel 11 Socialite Login Wit...

Hello, laravel web developers! In this article, we'll see how to Socialite login with github in laravel 11. In...

Read More

Aug-12-2024

Laravel 8 Custom Email Verification Tutorial
Laravel 8 Custom Email Verific...

In this article, we will see an example of laravel 8 custom email verification. Many web applications require users...

Read More

Dec-29-2021