Django的路由系统

URL配置(URL.conf)就像Django所支撑网站的目录,它的本质是URL与要为该URL调用的视图函数之间的映射表.

我们就是以这种方式告诉Django,遇到哪个URL的时候,要对应执行哪个函数.

URLconf配置

基本格式:

from django.conf.urls import url
urlpatterns = {
url(正则表达式,views视图,参数,别名),
}

示例:

from django.conf.urls import
from . import views
urlparterns = {
url(r'^articles/2003/$',views.special_case_2003),
url(r'^articles/([0-9]{4})/$',views.year_archive),
url(r'^articles/([0-9]{4})/([0-9]{2})/$',views.month_archive),
url(r'^articles/([0-9]{4})/([0-9]{2})/([0-9]+)/$',views.article_detall),
}

参数说明:

  • 正则表达式:一个正则表达式字符串
  • views视图:一个可调用对象,通常为一个视图函数
  • 参数:可选的要传递给视图函数的默认参数(字典形式)
  • 别名:一个可选的name参数

注意:

Django 2.0版本中的路由系统是下面的写法:(官方文档):

from django.urls import path,re_path

urlpatterns = [
path('articles/2003/', views.special_case_2003),
path('articles/<int:year>/', views.year_archive),
path('articles/<int:year>/<int:month>/', views.month_archive),
path('articles/<int:year>/<int:month>/<slug:slug>/', views.article_detail),
]

2.0版本的re_path和1.11版本的url是一样的用法.

正则表达式详解

from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^articles/2003/$',views.special_case_2003),
url(r'^articles/([0-9]{4})/$',views.year_archive),
url(r'^article/([0-9]{4})/([0-9]{2})/$',views.month_archive),
url(r'^article/([0-9]{4})/([0-9]{2})/([0-9]+)',views.article_detail),
]

注意事项:

1.urlpatterns中的元素按照书写顺序从上往下逐一匹配正则表达式,一旦匹配成功则不再继续.

2.若要从URL中捕获一个值,只需要在它周围放置一对圆括号(分组匹配).

3.不需要添加一个前导的反斜杠2,因为每个URL都有,例如,应该是^articles而不是^/articles.

4.每个正则表达式前面的'r'是可选的但是建议加上.

补充说明:

# 是否开启URL访问地址后面不为/跳转至带有/的路径的配置项
APPEND_SLASH=True. # 其作用就是在网址结尾加'/'

其效果就是:

我们定义了urls.py:

from django.conf.urls import url
from app01 import views
urlpatterns = [
url(r'^blog/$',views.blog)
]

访问http://www.example.com/blog 时,默认将网址自动转换为 http://www.example/com/blog/ 。

分组命名匹配

上面的示例使用简单的正则表达式分组匹配(通过圆括号)来捕获URL中的值并以位置参数形式传递给视图.

在更高级的用法中,可以使用分组命名匹配的正则表达式组来捕获URL中的值并以关键字参数形式传递给视图.

在Python的正则表达式中,分组命名正则表达式的语法是(?P<name>pattern),其中name是组的名称,pattern是要匹配的模式。

下面是以上URLconf 使用命名组的重写:

from django.conf.urls import url

from . import views

urlpatterns = [
url(r'^articles/2003/$', views.special_case_2003),
url(r'^articles/(?P<year>[0-9]{4})/$', views.year_archive),
url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.month_archive),
url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<day>[0-9]{2})/$', views.article_detail),
]

这个实现与前面的示例完全相同,只有一个细微的差别:捕获的值作为关键字参数而不是位置参数传递给视图函数。

例如,针对URL /articles/2017/12/相当于按以下方式调用视图函数:

views.month_archive(request, year="", month="")

在实际应用中,使用分组命名匹配的方式可以让你的URLconf 更加明晰且不容易产生参数顺序问题的错误,但是有些开发人员则认为分组命名组语法太丑陋、繁琐。

至于究竟应该使用哪一种,你可以根据自己的喜好来决定。

URLconf匹配的位置

URLconf 在请求的URL 上查找,将它当做一个普通的Python 字符串。不包括GET和POST参数以及域名。

例如,http://www.example.com/myapp/ 请求中,URLconf 将查找

在http://www.example.com/myapp/?page=3 请求中,URLconf 仍将查找

URLconf 不检查请求的方法。换句话讲,所有的请求方法 —— 同一个URL的POSTGETHEAD等等 —— 都将路由到相同的函数。

捕获的参数永远都是字符串

每个在URLconf中捕获的参数都作为一个普通的Python字符串传递给视图,无论正则表达式使用的是什么匹配方式。例如,下面这行URLconf 中:

url(r'^articles/(?P<year>[0-9]{4})/$', views.year_archive),

传递到视图函数views.year_archive() 中的year参数永远是一个字符串类型。

视图函数中的指定默认值

# urls.py中
from django.conf.urls import url from . import views urlpatterns = [
url(r'^blog/$', views.page),
url(r'^blog/page(?P<num>[0-9]+)/$', views.page),
] # views.py中,可以为num指定默认值
def page(request, num=""):
pass

最新文章

  1. iOS 25个性能优化/内存优化常用方法
  2. 使用Word2013发布博客
  3. UI: 窗口全屏, 窗口尺寸
  4. 集合List内容
  5. 在shell script中进行数值运算的两种方法
  6. 【POJ3237】Tree(树链剖分)
  7. codeforces 472C.Make It Nondeterministic 解题报告
  8. Alarm(硬件时钟) init
  9. Windows下搭建论坛
  10. Struts2通配符映射
  11. BZOJ 1199: [HNOI2005]汤姆的游戏 计算几何暴力
  12. MySQL精粹
  13. shell 多进程
  14. BZOJ 1192: [HNOI2006]鬼谷子的钱袋(新生必做的水题)
  15. [LeetCode] Car Fleet 车队
  16. Java面试题中的Redis大合集,所有你想找的都在这里!
  17. Oracle课程档案,第十二天
  18. Java IO流及应用(一)
  19. Akka-Cluster(1)- Cluster Singleton 单例节点
  20. full gc频繁的分析及解决案例

热门文章

  1. 201621123006 《Java程序设计》第2周学习总结
  2. 第7课:sql注入、操作session、cookie实例、网络编程、操作Excel
  3. APUE学习笔记——5.9Binary I/O 二进制读写
  4. svn 图标状态说明
  5. Android 开发 Tip 17 -- 为什么getBackground().setAlpha(); 会影响别的控件?
  6. linux前奏
  7. C++中的友元函数的总结
  8. HDU1576 A/B
  9. Srping框架中使用@query注解实现复杂查询
  10. 日志组件logback的介绍及配置使用方法(一)