kri55h / php-sitemapper
php-sitemapper: A lightweight and powerful PHP library for generating dynamic XML sitemaps effortlessly. Designed to help developers enhance their website's SEO by creating search-engine-friendly sitemaps, this tool is perfect for small and large-scale projects alike.
Installs: 24
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/kri55h/php-sitemapper
Requires
- php: >=7.4
- ext-json: *
Requires (Dev)
- phpunit/phpunit: ^9.6
This package is auto-updated.
Last update: 2025-10-09 14:31:14 UTC
README
SiteMapper is a lightweight, chainable PHP library to generate SEO-friendly XML sitemaps dynamically.
Designed for modern PHP projects and frameworks (Laravel, Codeigniter, Symfony, plain PHP).
Features
- Fluent API:
addUrl(...)->save()for concise, readable code. - Add per-URL metadata:
priority,lastmodandchangefreq. generateXml()returns an XML string ready to return from controllers.outputXml()sends correct headers and echoes XML directly.saveToFile()writes sitemap XML to disk.- Minimal dependencies — requires only PHP and SimpleXML.
Requirements
- PHP 7.4 or newer
ext-simplexmlenabled
Installation
Install via Composer:
composer require kri55h/php-sitemapper
Then autoload:
require 'vendor/autoload.php'; use Kri55h\SiteMapper;
Quick Example (recommended)
<?php require 'vendor/autoload.php'; use Kri55h\SiteMapper; $map = new SiteMapper(); // Add and save entries (pass full URLs) $map->addUrl('https://example.com/about', 0.8, '2025-08-09', 'daily')->save() ->addUrl('https://example.com/contact', 0.5, '2025-08-09', 'weekly')->save(); // Return XML from a controller or script header('Content-Type: application/xml; charset=UTF-8'); echo $map->generateXml();
Important: addUrl() stages a URL in memory. Call save() to commit the staged entry into the sitemap list — otherwise it will not appear in generateXml().
Full Example (all functions / backwards-compatible style)
<?php require 'vendor/autoload.php'; use Kri55h\SiteMapper; $map = new SiteMapper(); // Staged style: call setters, then save() $map->addUrl('https://example.com/') ->setPriority(1.0) ->setLastModified('2025-08-09') ->setChangeFrequency('daily') ->save(); // Another entry, using positional args $map->addUrl('https://example.com/about', 0.8, '2025-08-09', 'weekly')->save(); // Save sitemap to disk $map->saveToFile(__DIR__ . '/public/sitemap.xml'); // Or output directly (sets header + echoes XML) $map->outputXml();
Public API Reference
-
addUrl(string $location, ?float $priority = null, ?string $last_modified = null, ?string $change_frequency = null): selfAdds a staged URL entry. Pass a full URL (https://example.com/page). Returns $this for chaining. -
setPriority(float $priority): selfSet priority (0.0 — 1.0) for the currently staged entry. Chainable. -
setLastModified(string $last_modified): selfSet the last modified date (YYYY-MM-DD) for the currently staged entry. Chainable. -
setChangeFrequency(string $change_frequency): selfSet change frequency (always|hourly|daily|weekly|monthly|yearly|never). Chainable. -
save(): selfCommit the currently staged entry into the sitemap list. Throws RuntimeException if no loc was staged. Chainable. -
generateXml(): stringGenerate and return the sitemap XML string. Use this to return XML from controller routes. -
outputXml(): voidSend Content-Type: application/xml; charset=UTF-8 and echo the generated XML. Convenience helper for quick endpoints. -
saveToFile(string $filePath): voidWrite the generated sitemap XML to the given file path.
Migration notes (from previous versions that had addBaseUrl())
If you upgraded from a version that supported addBaseUrl() and relative paths:
- Before (old):
$map->addBaseUrl('https://example.com'); $map->addUrl('/about'); echo $map->generateXml();
- Now (new):
$map->addUrl('https://example.com/about')->save(); echo $map->generateXml();
Why: The library no longer maintains global base URL state. This makes the API explicit and safer for mixed-domain usages.
Best practices
-
Always call
save()afteraddUrl()(or use positional arguments withaddUrl(...)->save()). -
Use
generateXml()to return XML from controllers (so the framework can manage responses). -
Use
outputXml()only for simple scripts or endpoints where you want the library to send headers. -
For bulk imports, add entries in a loop and call
save()per entry, or implement your own batching helper.
License
This project is licensed under the MIT License.
Author
Krish Siddhapura — siddhapurakrish007@gmail.com — https://github.com/KRI55H
Keywords (for SEO)
PHP sitemap generator, XML sitemap, SEO sitemap PHP, SiteMapper, sitemap generator, Laravel sitemap generator, dynamic sitemap, Laravel dynamic sitemap generator.