Extension:AutoSitemap
AutoSitemap Stav rozšíření: stabilní |
|
---|---|
Implementace | MyWiki , Akce stránky |
Popis | Vytváří a aktualizuje soubor Sitemap automaticky, když se mění stránka libovolného webu. |
Autoři | Dolfinus, François Boutines-Vignard, Jehy, Thomas |
Nejnovější verze | 1.8.2 (2024-10-29) |
MediaWiki | 1.28+ |
Změny v databázi | Ne |
Licence | GNU General Public License 3.0 nebo novější |
Stáhnout | Stáhněte si hlavní snímek Poznámka: README |
Příklad | Vygenerovaná mapa webu |
$wgAutoSitemap |
|
The AutoSitemap extension automatically builds a "sitemap.xml" file at every page create/edit/delete event. Sitemap file helps search engines to observe your site’s pages. This extension is based on the extension ManualSitemap .
Rationale
I do not have the possibility to update my sitemap via scheduler (like cron) because of the hosting provider, and I also do not want to update it manually.
So I edited an existing extension to update the sitemap by itself at any page edit, create, delete, rename, upload, etc events.
Note
This extension can be used on small MediaWiki instances (up to 10k pages). If your instance is larger than 50k pages, you should use GenerateSitemap.php instead because it does support sitemap index file, can create separated files for each namespace, compress sitemap files and also designed to be run on schedule instead of triggering after each page modification.
Install
- Download soubor/y a vložte je do adresáře pojmenovaného
AutoSitemap
ve vaší složceextensions/
. - Na konec vašeho souboru LocalSettings.php přidejte následující kód:
wfLoadExtension( 'AutoSitemap' );
- Make any change of any of your wiki pages, e.g. create a page or update an existing one
- Sitemap file will be generated automatically
- Dokončeno – Přejděte na stránku Special:Version vaší wiki a zkontrolujte, zda bylo rozšíření úspěšně nainstalováno.
Configure
There are some optional parameters that change the sitemap generation. You can set them in your LocalSettings.php.
Filename
You can set filename of sitemap by setting:
$wgAutoSitemap["filename"] = "sitemap.xml"; //default value
Setting base URL
By default all URLs in sitemap use $wgCanonicalServer (or $wgServer, if it doesn’t set) as domain prefix. If you want to set it to another one, you can change it manually by setting:
$wgAutoSitemap["server"] = "https://your-site.com";
Exclude types of pages from sitemap
You can exclude namespaces or exact pages from including them to sitemap:
$wgAutoSitemap["exclude_namespaces"] = [
NS_TALK,
NS_USER,
NS_USER_TALK,
NS_PROJECT_TALK,
NS_FILE_TALK,
NS_MEDIAWIKI,
NS_MEDIAWIKI_TALK,
NS_TEMPLATE,
NS_TEMPLATE_TALK,
NS_HELP,
NS_HELP_TALK,
NS_CATEGORY_TALK
]; //default values
$wgAutoSitemap["exclude_pages"] = ['page title to exclude', 'other one'];
If you need to exclude custom namespace from sitemap, pass here namespace ID (integer) instead of name constant.
Set page update frequency
You can manually specify the recommended frequency with which all addresses will be checked by search engine:
$wgAutoSitemap["freq"] = "daily"; //default
Available values are:
hourly daily weekly monthly yearly adjust - for automatic determination of frequency based on page edits count
Set page priority
You can manually specify priority for certain pages or namespaces:
$wgAutoSitemap["priority"] = 0.7;
or
$wgAutoSitemap["priority"][NS_MAIN] = 1;
$wgAutoSitemap["priority"][NS_CATEGORY] = 0.8;
or
$wgAutoSitemap["priority"]['Main page'] = 1;
$wgAutoSitemap["priority"]['Other page'] = 0.8;
Rate-limit recreation of the sitemap
For wikis with many pages, generating the sitemap may consume significant resources, so you may not want it to happen too frequently. With this option, you can specify that the sitemap should only be recreated if it's at least a certain number of seconds old.
$wgAutoSitemap["min_age"] = 3600; // 1 hour, default 0 (no rate-limit)
Use
Blank page after installing extension
Please follow Příručka:Jak řešit chyby instruction to get exception message interrupting page render process.
Usually this is caused by passing undefined constant to $wgAutoSitemap["exclude_namespaces"]
.
Permissions
Your MediaWiki folder should be permitted for write operations (chmod +w
with chown apache
or chown nginx
).
Htaccess, Nginx
If you want to see a human-readable sitemap, allow read access for sitemap.xsl file in your site config (.htaccess
file or other).
See also
- w:Sitemaps - Wikipedia about sitemaps
- Google about sitemaps
- Stable extensions/cs
- Personalization extensions/cs
- Page action extensions/cs
- GPL licensed extensions/cs
- Extensions in GitHub version control/cs
- AfterImportPage extensions/cs
- PageDeleteComplete extensions/cs
- ArticleUndelete extensions/cs
- PageMoveComplete extensions/cs
- ArticleMergeComplete extensions/cs
- UploadComplete extensions/cs
- RevisionUndeleted extensions/cs
- RevisionRecordInserted extensions/cs
- PageSaveComplete extensions/cs
- All extensions/cs
- Sitemap extensions/cs