专栏首页JackeyGao的博客Django小技巧21: 使用重定向

Django小技巧21: 使用重定向

翻译整理自: simpleisbetterthancomplex.com

Django 附带了一组可以轻松安装的可选模块, 其中一个模块就是重定向的模块, 它在您想要更新某些现有URL而不损害您的网站SEO或在任何情况下避免404错误的情况下特别有用。

比如我现有的 URL 是

url

/tips/2017/08/11/django-tip-21.html

在某一次更新之后 URL 有变动变成了:

url

/tips/redirects-app/

而且我原有 URL, 已经被搜索引擎收录. 我不想在用户通过搜索引擎点过来是404页面。 这时候就需要做重定向到新的地址

redirects 模块是通过在数据库中创建一张表, 包含两个字段(old_path和new_path)来实现的.每当你的项目出现404错误的时候,redirects 组件将会拦截404响应, 并检索特定的 table 进行匹配, 如果在特定的 table 中匹配到old_path ,将会重定向到所绑定的new_path. 不会返回404, 而返回一个301响应(Moved Permanently).

OK, 让我看看redirects在实践中如何执行

安装

Django redirects 组件需要安装sites框架. 通过settings.pyINSTALLED_APPS来添加到项目中。

settings.py

Python

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',

    'django.contrib.sites',
    'django.contrib.redirects',
]

设置SITE_IDsites框架能够工作.

settings.py

Python

SITE_ID = 1

现在将redirects的中间件添加到MIDDLEWARE

settings.py

Python

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',

    'django.contrib.redirects.middleware.RedirectFallbackMiddleware',
]

通过migrate创建所需要的表:

Bash

python manage.py migrate

使用

最简单的方式通过 Django Admin 来对这个表添加记录. 如果你没有 Django Admin, 并且此操作是一次性的事情, 你可以通过redirects的 Python API 或者创建一个fixture. 如果你不使用Django Admin 但这个不是一次性的事情, 需要后面维护更新这个表, 那么你需要创建一个自己的视图管理页面.

通过DjangoAdmin管理redirects

默认情况下, 安装后会自动加到 Django Admin 界面

#Django Admin 管理 redirects

只需添加对应的路径, redirects组件将会自动完成这个重定向工作

#redirects table

你可以通过浏览器来访问旧的路径, 看看他是否能够正常的重定向. 另一种方法是检测响应的body, 可以通过curl来完成:

Bash

curl --head 127.0.0.1:8000/tips/2017/08/11/django-tip-21.html

HTTP/1.0 301 Moved Permanently
Date: Fri, 11 Aug 2017 15:42:27 GMT
Server: WSGIServer/0.2 CPython/3.6.1
Content-Type: text/html; charset=utf-8
Location: /tips/redirects-app/
X-Frame-Options: SAMEORIGIN
Content-Length: 0

通过Python API管理redirects

你可以通过 Django ORM 来对 redirects 的 Model 进行操作管理. 它位于django/contrib/redirects/models.py.

以下是创建redirects 条目的示例代码:

Python

from django.contrib.redirects.models import Redirect
from django.contrib.sites.models import Site
from django.conf import settings

site = Site.objects.get(pk=settings.SITE_ID)

Redirect.objects.create(site=site, old_path='/index.html', new_path='/')
Redirect.objects.create(site=site, old_path='/tips/2017/08/11/django-tip-21.html', new_path='/tips/redirects-app/')

通过Fixtures导入redirects

关于Fixtures, 是 Django 提供的一个功能, 可以到这里查看文档了解更多.

首先按照以下示例的模板创建 JSON 文件

redirects-fixture.json

JSON

[
   {
      "model":"redirects.redirect",
      "fields":{
         "site":1,
         "old_path":"/tips/2017/08/11/django-tip-21.html",
         "new_path":"/tips/redirects-app/"
      }
   },
   {
      "model":"redirects.redirect",
      "fields":{
         "site":1,
         "old_path":"/index.html",
         "new_path":"/"
      }
   }
]

然后通过命令将其加载到数据库

Bash

python manage.py loaddata redirects-fixtures.json
Installed 2 object(s) from 1 fixture(s)

就是这样~

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 大话西游答题器 command line

    用户1416054
  • 在网页中显示ansi终端颜色

    终端命令为了可以友好的显示大多数都支持了颜色显示。 在终端中良好的颜色显示, 能够让我们处理问题更加高效,但是在运维开发中, 难免要在 web 网页中操作服务器...

    用户1416054
  • Django小技巧02: humanize

    Django 附带一组模板过滤器, 可为您的数据添加人性化选项。它用于将数字或者日期转化为人类友好可读的格式.

    用户1416054
  • 61. Rotate List

    思路 先统计链表的长度n,如果k>n,就取k=k%n,如果k==0,就不用做变化,否则找到新链表头head2和它的前驱节点pre,将链表重新断开并连接,返回新...

    平凡的学生族
  • Innodb Buffer Pool的三种Page和链表

    Buffer Pool 是Innodb 内存中的的一块占比较大的区域,用来缓存表和索引数据。众所周知,从内存访问会比从磁盘访问快很多。为了提高数据的读取速度,B...

    用户1278550
  • 区块链节点的密钥管理

            本文主要讨论一种区块链节点的密钥管理方案。区块链节点都会有各自的私钥,将一段随机数分成两段,一段存在配置文件,一段写在节点的运行代码里,通过某种...

    tylerwen
  • 智能合约:访问控制缺陷

    访问控制缺陷是因为编写 solidity 智能合约的时候,对于某些判断的定义不严谨或者笔误,导致的某些敏感功能的访问验证被绕过问题。攻击者可以恶意使用某些敏感功...

    yichen
  • 海外服务器端口不通怎么解

    1 [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Terminal Server\Wds\rdp...

    乡村小男孩
  • python for循环if-else使

    a = [i*2 for i in mylist]; print(a) #[-2, 0, 2, 4, 6, 8]

    py3study
  • MySQL至TiDB复制延迟监控

    因生产环境mysql中有较多复杂sql且运行效率低,因此采用tidb作为生产环境的从库进行部分慢sql及报表的读写分离。其中MySQL至TIDB采用Syncer...

    July

扫码关注云+社区

领取腾讯云代金券