RSS добавлена, но нужно помочь поисковым системам индексировать сайт. А делается это с помощью файлов Sitemap, которые описывают структуру сайта. Django предоставляет готовые классы и механизмы для формирования файлов Sitemap , причём имеется возможность для формирования вложенных в основной Sitemap , то есть дочерних файлов Sitemap , которые будут отвечать за определённые разделы. Также Django имеет возможность кеширования файлов Sitemap, что полезно в том случае, если на сайте присутствуют десятки тысяч ссылок.
С точки зрения текущего состояния сайта EVILEG COM будет сформировано три файла Sitemap, которые будут вложены в один главный:
- Основной Sitemap с постоянными страницами и главной страницей сайта;
- Sitemap разделов;
- Sitemap статей.
Настройка settings.py
Для начала настроим конфигурационный файл сайта, чтобы была возможность работать с файлами Sitemap.
- SITE_ID = 1
- INSTALLED_APPS = [
- ...
- 'django.contrib.sitemaps',
- 'django.contrib.sites',
- ...
- ]
SITE_ID необходим дя идентификации ресурса в базе данных. Если не будет добавлен данный параметр, то в админке сайта не получится прописать url вашего сайта, для которого делается Sitemap . Карта сайта для поисковиков просто не будет формироваться тогда. После того, как настройка сайта появится в админке, тогда нужно будет прописать домен вашего сайта, иначе в Sitemap url будут начинаться с example.com .
Что касается INSTALLED_APPS , то тут всё должно быть понятно. Первый модуль отвечает за работу с sitemaps, а второй модуль отвечает непосредственно за работу с параметром SITE_ID в базе данных.
Настройка urls.py основного приложения сайта
Говоря про основное приложение, я подразумеваю то приложение, в папке которого находится файл settings.py. В текущей реализации сайта все url Sitemap описаны в файле urls.py как раз этого самого основного приложения всего сайта.
Давайте разберёмся, что и за что отвечает.
- from django.contrib.sitemaps import views as sitemap_views # Представление
- from django.contrib.sitemaps import GenericSitemap # Шаблонный класс для формирования страницы Sitemap
- from django.views.decorators.cache import cache_page # Декоратор кеширования
- from knowledge import models as knowledge_models # Модели статей и разделов, по которым будет формироваться Sitemap
- from home.sitemap import HomeSitemap # Статический Sitemap для относительно постоянных страниц
- # Объект карты разделов. Здесь просто забираются все объекты из базы данных,
- # а также по одноимённому полю в модели забирается дата последней модификации
- sitemap_sections = {
- 'queryset': knowledge_models.Section.objects.all(),
- 'date_field': 'section_lastmod',
- }
- # А вот со статьями уже интереснее. Здесь забираются только те статьи, которые опубликованы
- # И для этого нужно будет написать специальный менеджер
- sitemap_articles = {
- 'queryset': knowledge_models.Article.objects.article_status(),
- 'date_field': 'article_date',
- }
- # Формируем объект со всеми картами и присваиваем им наименования
- sitemaps = {
- 'sections': GenericSitemap(sitemap_sections, priority=0.5),
- 'articles': GenericSitemap(sitemap_articles, priority=0.5),
- 'home': HomeSitemap
- }
- # Шаблоны URL, заметьте, здесь указано кеширование cache_page(86400)
- # Первый шаблон будет формировать основную карту сайта, в которой будут указаны URL дочерних,
- # То есть 'sitemap-sections', 'sitemap-articles', 'sitemap-home'
- # Заметили, что их названия перекликаются с названиями параметров в объекте sitemaps?
- urlpatterns += [
- url(r'^sitemap\.xml$', cache_page(86400)(sitemap_views.index), {'sitemaps': sitemaps}),
- url(r'^sitemap-(?P<section>\w+)\.xml$', cache_page(86400)(sitemap_views.sitemap), {'sitemaps': sitemaps},
- name='django.contrib.sitemaps.views.sitemap'),
- ]
Статический Sitemap
Для начала разберёмся со статическим Sitemap, который означает, что в нём будут перечислены страницы наподобие страницы контактов, главной страницы, предложений и т.д. В моём случае он располагается в приложении home.
- from django.contrib import sitemaps
- from django.urls import reverse # Этот метод необходим, чтобы получить url из шаблона
- class HomeSitemap(sitemaps.Sitemap):
- priority = 0.5 # Приоритет
- changefreq = 'daily' # Частота проверки
- # Метод, возвращающий массив с url-ками
- def items(self):
- return ['home:index', 'home:contacts']
- # Метод непосредственной экстракции url из шаблона
- def location(self, item):
- return reverse(item)
Модель Section
Для того, чтобы сформировать url-ки Sitemap из Модели необходимо, чтобы в данной модели присутствовал метод get_absolute_url. И вообще рекомендую добавить этот метод пораньше, поскольку им очень удобно пользоваться как в шаблонах, так и любом другом месте кода.
Я оставлю только необходимое для формирования Sitemap в данной модели, чтобы не загромождать код.
- class Section(models.Model):
- ...
- section_url = models.CharField('URL Раздела', max_length=50)
- def get_absolute_url(self):
- return reverse('knowledge:section', kwargs={'section': self.section_url})
Как видите, в модели содержится часть адреса раздела, который подставляется в шаблон 'knowledge:section'
Модель Article
Здесь тоже самое, что и с разделами за исключением того, что добавлен ArticleManager , который подменяет собой objects , чтобы расширить комплект методов, например методом article_status , по которому забираются только те статьи, которые уже опубликованы. И именно этот метод вместо метода all , вы можете увидеть в файле urls.py при формировании карт статей.
- class ArticleManager(models.Manager):
- use_for_related_fields = True
- def article_status(self):
- return self.get_queryset().exclude(article_status=False)
- class Article(models.Model):
- ...
- article_section = models.ForeignKey(Section)
- objects = ArticleManager() # объекты queryset подменяются менеджером
- # для расширения функционала
- def get_absolute_url(self):
- return reverse('knowledge:article', kwargs={'section': self.article_section.section_url,
- 'article_id': self.id})
Для Django рекомендую VDS-сервера хостера Timeweb .