1. Go to this page and download the library: Download roumen/sitemap library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
roumen / sitemap example snippets
use Rumenx\Sitemap\Sitemap;
public function sitemap(Sitemap $sitemap)
{
$sitemap->add('https://example.com/', now(), '1.0', 'daily');
$sitemap->add('https://example.com/about', now(), '0.8', 'monthly', images: [
['url' => 'https://example.com/img/about.jpg', 'title' => 'About Us']
]);
// Add more items as needed...
// Render XML using a view template
$items = $sitemap->getModel()->getItems();
return response()->view('sitemap.xml', compact('items'), 200, ['Content-Type' => 'application/xml']);
}
use Rumenx\Sitemap\Sitemap;
use Symfony\Component\HttpFoundation\Response;
class SitemapController
{
public function sitemap(): Response
{
$sitemap = new Sitemap();
$sitemap->add('https://example.com/', (new \DateTime())->format(DATE_ATOM), '1.0', 'daily');
$sitemap->add('https://example.com/contact', (new \DateTime())->format(DATE_ATOM), '0.5', 'monthly');
// Add more items as needed...
// Render XML
$xml = $sitemap->renderXml();
return new Response($xml, 200, ['Content-Type' => 'application/xml']);
}
}
use Rumenx\Sitemap\Sitemap;
$sitemap = new Sitemap();
$sitemap->add('https://example.com/', date('c'), '1.0', 'daily');
$sitemap->add('https://example.com/products', date('c'), '0.9', 'weekly', [
['url' => 'https://example.com/img/product.jpg', 'title' => 'Product Image']
]);
// Output XML
header('Content-Type: application/xml');
echo $sitemap->renderXml();
// Add with all supported fields
$sitemap->add(
'https://example.com/news',
date('c'),
'0.8',
'daily',
images: [['url' => 'https://example.com/img/news.jpg', 'title' => 'News Image']],
title: 'News Article',
translations: [['language' => 'fr', 'url' => 'https://example.com/fr/news']],
videos: [['title' => 'News Video', 'description' => 'Video description']],
googlenews: [
'sitename' => 'Example News',
'language' => 'en',
'publication_date' => date('c'),
],
alternates: [['media' => 'print', 'url' => 'https://example.com/news-print']]
);
// Generate XML using renderXml() method
$xml = $sitemap->renderXml();
file_put_contents('sitemap.xml', $xml);
// Or use view templates for more control (create your own views based on src/views/)
$items = $sitemap->getModel()->getItems();
// Pass $items to your view template
// Recommended for most use cases
$sitemap->add(
'https://example.com/',
date('c'),
'1.0',
'daily',
images: [['url' => 'https://example.com/img.jpg', 'title' => 'Image']],
title: 'Homepage'
);
// Add a single item with an array (all fields as keys)
$sitemap->addItem([
'loc' => 'https://example.com/about',
'lastmod' => date('c'),
'priority' => '0.8',
'freq' => 'monthly',
'title' => 'About Us',
'images' => [['url' => 'https://example.com/img/about.jpg', 'title' => 'About Us']],
]);
// Add multiple items at once (batch add)
$sitemap->addItem([
[
'loc' => 'https://example.com/page1',
'title' => 'Page 1',
],
[
'loc' => 'https://example.com/page2',
'title' => 'Page 2',
],
]);
$sitemap = new Sitemap();
$sitemap->add('https://example.com/', date('c'), '1.0', 'daily');
$xml = $sitemap->renderXml(); // Returns XML string
$sitemap = new Sitemap();
$sitemap->add('https://example.com/', date('c'), '1.0', 'daily');
// Get the data for your view
$items = $sitemap->getModel()->getItems();
// Laravel: Use response()->view() or view()->render()
return response()->view('sitemap.xml', compact('items'), 200, ['Content-Type' => 'application/xml']);
// Symfony: Use Twig templates
return $this->render('sitemap.xml.twig', ['items' => $items], new Response('', 200, ['Content-Type' => 'application/xml']));
// Generic PHP: Include view templates
ob_start();
bash
composer
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.