serg / sitemap-php
Lightweight library for generating Google sitemap XML files
Requires
- php: >=5.3.0
This package is auto-updated.
Last update: 2025-04-29 01:25:06 UTC
README
Fast and lightweight class for generating Google sitemap XML files and index of sitemap files. Written on PHP and uses XMLWriter extension (wrapper for libxml xmlWriter API) for creating XML files. XMLWriter extension is enabled by default in PHP 5 >= 5.1.2. If you having more than 50000 url, it splits items to seperated files. (In benchmarks, 1.000.000 url was generating in 8 seconds)
This is a slightly modified version of the original. The Sitemap class is now added to a 'SitemapPHP' namespace, and a composer document has been added.
Requirements
- PHP 5.1.2 and above
Steps:
Installation
Composer
Run the following command to include this package via Composer
composer require serg/sitemap-php
Include
Include Sitemap.php file to your PHP document and call Sitemap class with your base domain.
include 'src/SitemapPHP/Sitemap.php';
Usage
use SitemapPHP\Sitemap; $sitemap = new Sitemap('http://test.com');
Now, we need to define path for saving XML files.
$sitemap->setSitemapPath('xmls/');
Define path for saving sitemap-index.xml
$sitemap->setIndexPath('xmls/');
Set number of items on sitemap (default 50000)
$sitemap->setNumberOfItems(10000);
Generated XML file names defaulted to sitemap-*.xml
, you can customize prefix of filenames with setFilename
method.
$sitemap->setFilename('customsitemap');
We'll add sitemap url's with addItem
method. In this method, only first parameter (location) is required.
$sitemap->addItem('/', '1.0', 'daily', 'Today'); $sitemap->addItem('/about', '0.8', 'monthly', 'Jun 25'); $sitemap->addItem('/contact', '0.6', 'yearly', '14-12-2009'); $sitemap->addItem('/otherpage');
w/ method chaining.
$sitemap->addItem('/projects', '0.8')->addItem('/somepage')->addItem('/hiddenpage', '0.4', 'yearly', '01-01-2011')->addItem('/rss');
from a sql result, or whatever.
$query = Doctrine_Query::create() ->select('p.created_at, p.slug') ->from('Posts p') ->orderBy('p.id DESC') ->useResultCache(true); $posts = $query->fetchArray(array(), Doctrine_Core::HYDRATE_ARRAY); foreach ($posts as $post) { $sitemap->addItem('/post/' . $post['slug'], '0.6', 'weekly', $post['created_at']); }
If you need to change domain for sitemap instance, you can override it via setDomain
method.
$sitemap->setDomain('http://blog.example.com');
Finally we create index for sitemap files. This method also closes tags of latest generated xml file.
$sitemap->createSitemapIndex('http://example.com/sitemap/', 'Today');
When you run your script, it generates and saves XML files to given path.
sitemap-0.xml
<?xml version="1.0" encoding="UTF-8"?>
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
<url>
<loc>http://example.com/</loc>
<priority>1.0</priority>
<changefreq>daily</changefreq>
<lastmod>2011-04-07</lastmod>
</url>
<url>
<loc>http://example.com/about</loc>
<priority>0.8</priority>
<changefreq>monthly</changefreq>
<lastmod>2011-06-25</lastmod>
</url>
<url>
<loc>http://example.com/contact</loc>
<priority>0.6</priority>
<changefreq>yearly</changefreq>
<lastmod>2009-12-14</lastmod>
</url>
<url>
<loc>http://example.com/otherpage</loc>
<priority>0.5</priority>
</url>
</urlset>
sitemap-index.xml
<?xml version="1.0" encoding="UTF-8"?>
<sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
<sitemap>
<loc>http://example.com/sitemap/sitemap-0.xml</loc>
<lastmod>2011-04-07</lastmod>
</sitemap>
</sitemapindex>
You need to submit sitemap-index.xml to Google Sitemaps.