Django 的路由分配系统
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的POST
、GET
、HEAD
等等 —— 都将路由到相同的函数。
捕获的参数永远都是字符串
每个在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
最新文章
- iOS 25个性能优化/内存优化常用方法
- 使用Word2013发布博客
- UI: 窗口全屏, 窗口尺寸
- 集合List内容
- 在shell script中进行数值运算的两种方法
- 【POJ3237】Tree(树链剖分)
- codeforces 472C.Make It Nondeterministic 解题报告
- Alarm(硬件时钟) init
- Windows下搭建论坛
- Struts2通配符映射
- BZOJ 1199: [HNOI2005]汤姆的游戏 计算几何暴力
- MySQL精粹
- shell 多进程
- BZOJ 1192: [HNOI2006]鬼谷子的钱袋(新生必做的水题)
- [LeetCode] Car Fleet 车队
- Java面试题中的Redis大合集,所有你想找的都在这里!
- Oracle课程档案,第十二天
- Java IO流及应用(一)
- Akka-Cluster(1)- Cluster Singleton 单例节点
- full gc频繁的分析及解决案例
热门文章
- 201621123006 《Java程序设计》第2周学习总结
- 第7课:sql注入、操作session、cookie实例、网络编程、操作Excel
- APUE学习笔记——5.9Binary I/O 二进制读写
- svn 图标状态说明
- Android 开发 Tip 17 -- 为什么getBackground().setAlpha(); 会影响别的控件?
- linux前奏
- C++中的友元函数的总结
- HDU1576 A/B
- Srping框架中使用@query注解实现复杂查询
- 日志组件logback的介绍及配置使用方法(一)