RSS қосылды, бірақ іздеу жүйелеріне сайтты индекстеуге көмектесу керек. Және бұл сайттың құрылымын сипаттайтын Сайт картасы, файлдары арқылы орындалады. Django Сайт картасы файлдарын жасау үшін дайын сыныптар мен механизмдерді ұсынады және кірістірілген Сайт картасы , яғни белгілі бір әрекеттерге жауап беретін еншілес Сайт картасы файлдарын құруға болады. бөлімдер. Сондай-ақ, Django сайт картасы файлдарын кэштеу мүмкіндігіне ие, бұл сайтта ондаған мың сілтемелер болса пайдалы.
EVILEG COM сайтының ағымдағы күйі тұрғысынан үш Сайт картасы файлы жасалады, олар бір негізгіге орналастырылады:
- Тұрақты беттері бар негізгі сайт картасы және сайттың басты беті;
- Сайт картасының бөлімдері;
- Сайт картасы туралы мақалалар.
settings.py параметрін орнату
Алдымен Сайт картасы файлдарымен жұмыс істеу үшін тораптың конфигурация файлын баптайық.
SITE\_ID = 1 INSTALLED\_APPS = [ ... 'django.contrib.sitemaps', 'django.contrib.sites', ... ]
SITE_ID дерекқордағы ресурсты анықтау үшін қажет. Егер бұл параметр қосылмаса, сайттың әкімші панелінде Сайт картасы жасалып жатқан сайттың url мекенжайын тіркеу мүмкін болмайды. Іздеу жүйелеріне арналған сайт картасы сол кезде құрылмайды. Сайт параметрі әкімші панелінде пайда болғаннан кейін сайтыңыздың доменін тіркеу керек болады, әйтпесе Сайт картасы url example.com арқылы басталады.
Орнатылған_Қолданбаларға келетін болсақ, онда бәрі түсінікті болуы керек. Бірінші модуль сайт карталарымен жұмыс істеуге жауап береді, ал екінші модуль дерекқордағы SITE_ID параметрімен жұмыс істеуге тікелей жауап береді.
Негізгі сайт қолданбасының urls.py параметрін орнату
Негізгі қолданба туралы айтатын болсам, мен settings.py файлы орналасқан қалтадағы қолданбаны айтып отырмын. Сайттың ағымдағы іске асырылуында Сайт картасының барлық URL мекенжайлары осы 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'), ]
Статикалық сайт картасы
Алдымен, статикалық сайт картасымен айналысайық, яғни ол контакт беті, басты бет, ұсыныстар және т.б. сияқты беттерді тізімдейді. Менің жағдайда ол үй. қолданбасында орналасқан.
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)
Бөлім үлгісі
Модельден Сайт картасының URL мекенжайларын жасау үшін осы үлгіде get_absolute_url әдісі болуы қажет. Жалпы, бұл әдісті ертерек қосуды ұсынамын, өйткені оны екеуінде де пайдалану өте ыңғайлы. үлгілерде және кез келген басқа код орнында.
Мен кодты шатастырмас үшін осы үлгіде Сайт картасын қалыптастыру үшін қажет нәрсені ғана қалдырамын.
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})
Көріп отырғаныңыздай, үлгіде бөлім мекенжайының бір бөлігі бар, ол "білім: бөлім" үлгісіне ауыстырылады.
Мақала үлгісі
Бұл бөлімдермен бірдей, тек әдістер жинағын кеңейту үшін объектілерді ауыстыратын ArticleManager қосылғанын қоспағанда, мысалы, 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 үшін Timeweb хостының VDS-сервері ұсынамын.