前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django设置网站地图sitemap

Django设置网站地图sitemap

作者头像
菲宇
发布2022-05-06 13:24:52
7140
发布2022-05-06 13:24:52
举报
文章被收录于专栏:菲宇菲宇

1.安装

安装Sitemap APP的步骤如下:

  1. 在INSTALLED_APPS设置中添加'django.contrib.sitemaps';
  2. 确认你的TEMPLATES设置中包含DjangoTemplates后端,并将APP_DIRS选项设置为True,当然默认值就是这样,只有当你曾经修改过这些设置,才需要修改这个配置;
  3. 确认你已经安装sites framework.(在INSTALLED_APPS中添加'django.contrib.sites', 并添加设置SITE_ID=1,运行magrite)

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')

参考:https://docs.djangoproject.com/zh-hans/2.1/ref/contrib/sitemaps/

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-04-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.安装
  • 2.例子
  • 3.静态视图的Sitemap
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档