PHP
Laravel
How To Automatically Generate Sitemap In Laravel?
Here, I will show you laravel generate sitemap. This article goes in detailed on how to create dynamic xml sitemap in laravel. I explained simply step by step laravel sitemap xml. Here you will learn laravel sitemap dynamic generate. Here, Creating a basic example of laravel generate sitemap file.
- 4.5/5.0
- Last updated 05 September, 2022
- By Admin
you can use this example with laravel 6, laravel 7, laravel 8 and laravel 9 versions.
A sitemap is an XML File that has a list of URLs of your website. You can submit a sitemap file to the webmaster tool to inform the search engine. So Sitemap is very important for every website SEO.
In this example, we will create posts table with title, slug and body. Then we will create a factory for dummy posts. Then after we will generate an XML file and list all URLs for posts. It's a very basic example. so let's follow and you will get a sitemap file for your website and submit it to the webmaster's tool.
Let's follow below steps:
Step 1: Install Laravel
This step is not required; however, if you have not created the laravel app, then you may go ahead and execute the below command:
composer create-project laravel/laravel example-app
Step 2: Create Post Migration and Model
In this step, we will create migration and model. So let's run below command to create posts table.
php artisan make:migration create_posts_table
Next, simple update below code to migration file.
database/migrations/create_posts_table.php
id(); $table->string('title'); $table->string('slug'); $table->text('body'); $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('posts'); } }; ?>
Then run created new migration with below command:
php artisan migrate
Now, run below command to create Post model.
php artisan make:model Post
Then update following code to Post model.
app/Models/Post.php
Step 3: Create Post Factory
In this step, we will create Post factory class and generate dummy records using tinker command. so let's run below command to create post factory.
php artisan make:factory PostFactory
Next, copy below code and update PostFactory.php file.
database/factories/PostFactory.php
*/ class PostFactory extends Factory { /** * The name of the factory's corresponding model. * * @var string */ protected $model = Post::class; /** * Define the model's default state. * * @return array */ public function definition() { return [ 'title' => $this->faker->text(), 'slug' => Str::slug($this->faker->text()), 'body' => $this->faker->paragraph() ]; } } ?>
Then simply run tinker command and create dummy posts.
php artisan tinker App\Models\Post::factory()->count(30)->create();
Step 4: Create Route
In this step, we will create one route sitemap.xml. so let's add it.
routes/web.php
Next, copy below code and update PostFactory.php file.
Step 5: Create Controller
In this step, we have to create new controller as SitemapController with index(). we will get all posts and pass to blade file. we will return response as xml file. so let's update follow code:
app/Http/Controllers/SitemapController.php
get(); return response()->view('sitemap', [ 'posts' => $posts ])->header('Content-Type', 'text/xml'); } } ?>
Step 6: Create View File
In Last step, let's create sitemap.blade.php for display all posts and put following code:
resources/views/sitemap.blade.php
'; ?> @foreach ($posts as $post) @endforeach {{ url('/') }}/post/{{ $post->slug }} {{ $post->created_at->tz('UTC')->toAtomString() }} daily 0.8
Run Laravel App:
All the required steps have been done, now you have to type the given below command and hit enter to run the Laravel app:
php artisan serve
Now, Go to your web browser, type the given URL and view the app output:
http://localhost:8000/sitemap.xml
I hope it can help you...