1.安装
安装Sitemap APP的步骤如下:
- 在INSTALLED_APPS设置中添加'django.contrib.sitemaps';
- 确认你的TEMPLATES设置中包含DjangoTemplates后端,并将APP_DIRS选项设置为True,当然默认值就是这样,只有当你曾经修改过这些设置,才需要修改这个配置;
- 确认你已经安装sites framework.(在INSTALLED_APPS中添加'django.contrib.sites', 并添加设置SITE_ID=1)
2.例子
假设拥有一个News模型,并且您希望Sitemap包含指向所有新闻条目的链接.
# sitemaps.py
from django.contrib.sitemaps import Sitemap
from myweb.models import News
from django.urls import reverse
class NewsSitemap(Sitemap):
changefreq = 'daily' # 可选,指定每个对象的更新频率
priority = 0.6 # 可选,指定每个对象的优先级,默认0.5
def items(self): # 返回对象的列表.这些对象将被其他方法或属性调用
return News.objects.all()
def lastmod(self, obj): # 可选,该方法返回一个datetime,表示每个对象的最后修改时间
return obj.pub_time
def location(self, obj):#可选.返回每个对象的绝对路径.如果对象有get_absolute_url()方法,可以省略location
return reverse('new', kwargs={'new_id': obj.id})
# url.py
from django.contrib.sitemaps import sitemap # 导入sitemap视图
from xxx.sitemaps import NewsSitemap
sitemaps = {
'new': NewsSitemap,
}
urlpatterns = [
...
url(r'^sitemap\.xml$', sitemap, {'sitemap': sitemaps}, name='django.contrib.sitemaps.views.sitemap'),
]
当客服端访问 /sitemap.xml时,这将告诉Django生成一个Sitemap.
sitemap视图需要一个额外的必需参数:{sitemaps': sitemaps}
.sitemaps
是一个字典,将小节的标签(例如:new或blog)映射到Sitemap类(例如:NewsSitemap).它也可以映射到Sitemap类的实例(例如: NewsSitemap(some_var)).
3.静态视图的Sitemap
通常,您希望搜索引擎抓取工具索引既不是对象详细信息页面也不是列表页的视图(例如index页面)。解决方案是在 items
中显式列出这些视图的网址名称,并在网站地图的 location
方法中调用 reverse()
from django.contrib.sitemaps import Sitemap
from django.urls import reverse
class StaticViewSitmap(Sitemap):
priority = 0.7
changefreq = 'daily'
def items(self):
return ['index']
def location(self, obj):
return reverse('index')