2017 © Pedro Peláez
 

library sitemap

Sitemap and sitemap index builder

image

samdark/sitemap

Sitemap and sitemap index builder

  • Tuesday, July 10, 2018
  • by samdark
  • Repository
  • 29 Watchers
  • 339 Stars
  • 90,286 Installations
  • PHP
  • 14 Dependents
  • 0 Suggesters
  • 62 Forks
  • 2 Open issues
  • 15 Versions
  • 12 % Grown

The README.md

Sitemap

XML Sitemap and XML Sitemap Index builder., (*1)

GitHub release (latest SemVer) GitHub Workflow Status (branch) Packagist PHP Version Support Packagist Downloads Packagist Downloads GitHub, (*2)

Features

  • Create sitemap files: either regular or gzipped.
  • Create multi-language sitemap files.
  • Create sitemap index files.
  • Use custom stylesheet.
  • Automatically creates new file if either URL limit or file size limit is reached.
  • Fast and memory efficient.

Installation

Installation via Composer is very simple:, (*3)

composer require samdark/sitemap

After that, make sure your application autoloads Composer classes by including vendor/autoload.php., (*4)

How to use it

use samdark\sitemap\Sitemap;
use samdark\sitemap\Index;

// create sitemap
$sitemap = new Sitemap(__DIR__ . '/sitemap.xml');

// add some URLs
$sitemap->addItem('http://example.com/mylink1');
$sitemap->addItem('http://example.com/mylink2', time());
$sitemap->addItem('http://example.com/mylink3', time(), Sitemap::HOURLY);
$sitemap->addItem('http://example.com/mylink4', time(), Sitemap::DAILY, 0.3);

// set sitemap stylesheet (see example-sitemap-stylesheet.xsl)
$sitemap->setStylesheet('http://example.com/css/sitemap.xsl');

// write it
$sitemap->write();

// get URLs of sitemaps written
$sitemapFileUrls = $sitemap->getSitemapUrls('http://example.com/');

// create sitemap for static files
$staticSitemap = new Sitemap(__DIR__ . '/sitemap_static.xml');

// add some URLs
$staticSitemap->addItem('http://example.com/about');
$staticSitemap->addItem('http://example.com/tos');
$staticSitemap->addItem('http://example.com/jobs');

// set optional stylesheet (see example-sitemap-stylesheet.xsl)
$staticSitemap->setStylesheet('http://example.com/css/sitemap.xsl');

// write it
$staticSitemap->write();

// get URLs of sitemaps written
$staticSitemapUrls = $staticSitemap->getSitemapUrls('http://example.com/');

// create sitemap index file
$index = new Index(__DIR__ . '/sitemap_index.xml');

// set index stylesheet (see example in repo)
$index->setStylesheet('http://example.com/css/sitemap.xsl');

// add URLs
foreach ($sitemapFileUrls as $sitemapUrl) {
    $index->addSitemap($sitemapUrl);
}

// add more URLs
foreach ($staticSitemapUrls as $sitemapUrl) {
    $index->addSitemap($sitemapUrl);
}

// write it
$index->write();

Multi-language sitemap

use samdark\sitemap\Sitemap;

// create sitemap
// be sure to pass `true` as second parameter to specify XHTML namespace
$sitemap = new Sitemap(__DIR__ . '/sitemap_multi_language.xml', true);

// Set URL limit to fit in default limit of 50000 (default limit / number of languages) 
$sitemap->setMaxUrls(25000);

// add some URLs
$sitemap->addItem('http://example.com/mylink1');

$sitemap->addItem([
    'ru' => 'http://example.com/ru/mylink2',
    'en' => 'http://example.com/en/mylink2',
], time());

$sitemap->addItem([
    'ru' => 'http://example.com/ru/mylink3',
    'en' => 'http://example.com/en/mylink3',
], time(), Sitemap::HOURLY);

$sitemap->addItem([
    'ru' => 'http://example.com/ru/mylink4',
    'en' => 'http://example.com/en/mylink4',
], time(), Sitemap::DAILY, 0.3);

// set stylesheet (see example-sitemap-stylesheet.xsl)
$sitemap->setStylesheet('http://example.com/css/sitemap.xsl');

// write it
$sitemap->write();

Options

There are methods to configure Sitemap instance:, (*5)

  • setMaxUrls($number). Sets maximum number of URLs to write in a single file. Default is 50000 which is the limit according to specification and most of existing implementations.
  • setMaxBytes($number). Sets maximum size of a single site map file. Default is 10MiB which should be compatible with most current search engines.
  • setBufferSize($number). Sets number of URLs to be kept in memory before writing it to file. Default is 10. Bigger values give marginal benefits. On the other hand when the file size limit is hit, the complete buffer must be written to the next file.
  • setUseIndent($bool). Sets if XML should be indented. Default is true.
  • setUseGzip($bool). Sets whether the resulting sitemap files will be gzipped or not. Default is false. zlib extension must be enabled to use this feature.
  • setStylesheet($string). Sets the xml-stylesheet tag. By default, tag is not generated. See example example-sitemap-stylesheet.xsl

There is a method to configure Index instance:, (*6)

  • setUseGzip($bool). Sets whether the resulting index file will be gzipped or not. Default is false. zlib extension must be enabled to use this feature.
  • setStylesheet($string). Sets the xml-stylesheet tag. By default, tag is not generated. See example example-sitemap-stylesheet.xsl

Running tests

In order to run tests perform the following commands:, (*7)

composer install
./vendor/bin/phpunit

The Versions

10/07 2018

3.0.0.x-dev

3.0.0.9999999-dev https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=7.1.0
  • ext-xmlwriter *

 

The Development Requires

sitemap

02/02 2018

dev-master

9999999-dev https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.3.0
  • ext-xmlwriter *

 

The Development Requires

sitemap

02/02 2018

2.2.0

2.2.0.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.3.0
  • ext-xmlwriter *

 

The Development Requires

sitemap

24/11 2017

2.1.0

2.1.0.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.3.0

 

The Development Requires

sitemap

17/08 2017

2.0.8

2.0.8.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.3.0

 

The Development Requires

sitemap

28/01 2017

2.0.7

2.0.7.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.3.0

 

The Development Requires

sitemap

04/10 2016

2.0.6

2.0.6.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.3.0

 

sitemap

29/09 2016

2.0.5

2.0.5.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.3.0

 

sitemap

05/07 2016

2.0.4

2.0.4.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.3.0

 

sitemap

29/04 2016

2.0.3

2.0.3.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.4.0

 

sitemap

22/04 2016

dev-refactroring

dev-refactroring https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.4.0

 

The Development Requires

sitemap

14/07 2015

2.0.2

2.0.2.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.4.0

 

sitemap

13/07 2015

2.0.1

2.0.1.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.4.0

 

sitemap

03/07 2015

2.0.0

2.0.0.0 https://github.com/samdark/sitemap

Sitemap and sitemap index builder

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.4.0

 

sitemap

29/06 2015

1.0.0

1.0.0.0 https://github.com/samdark/sitemap

Very simple abstraction for sitemap generation

  Sources   Download

BSD-3-Clause

The Requires

  • php >=5.4.0

 

sitemap