1. 概述

URL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL模式以及

2. path转换器

在django2.0 以上的版本中,默认使用的是path转换器,我们首先以此举例:

from django.urls import path
from . import views 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),
]

注意:

  1. 要捕获一段url中的值,需要使用尖括号,而不是之前的圆括号;
  2. 可以转换捕获到的值为指定类型,比如例子中的int。默认情况下,捕获到的结果保存为字符串类型,不包含/这个特殊字符;
  3. 匹配模式的最开头不需要添加/,因为默认情况下,每个url都带一个最前面的/,既然大家都有的部分,就不用浪费时间特别写一个了。

匹配例子:

  • /articles/2005/03/ 将匹配第三条,并调用views.month_archive(request, year=2005, month=3);
  • /articles/2003/匹配第一条,并调用views.special_case_2003(request);
  • /articles/2003将一条都匹配不上,因为它最后少了一个斜杠,而列表中的所有模式中都以斜杠结尾;
  • /articles/2003/03/building-a-django-site/ 将匹配最后一个,并调用views.article_detail(request, year=2003, month=3, slug="building-a-django-site"

默认情况下,Django内置下面的路径转换器:

  • str:匹配任何非空字符串,但不含斜杠/,如果你没有专门指定转换器,那么这个是默认使用的;
  • int:匹配0和正整数,返回一个int类型
  • slug:可理解为注释、后缀、附属等概念,是url拖在最后的一部分解释性字符。该转换器匹配任何ASCII字符以及连接符和下划线,比如’ building-your-1st-django-site‘;
  • uuid:匹配一个uuid格式的对象。为了防止冲突,规定必须使用破折号,所有字母必须小写,例如’075194d3-6885-417e-a8a8-6c931e272f00‘ 。返回一个UUID对象;
  • path:匹配任何非空字符串,重点是可以包含路径分隔符’/‘。这个转换器可以帮助你匹配整个url而不是一段一段的url字符串。

3. re_path转换器(老版url)

Django2.0的url虽然改‘配置’了,但它依然向老版本兼容。而这个兼容的办法,就是用re_path()方法代替path()方法。

from django.urls import path, re_path
from . import views urlpatterns = [
path('articles/2003/', views.special_case_2003),
re_path(r'^articles/(?P<year>[0-9]{4})/$', views.year_archive),
re_path(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.month_archive),
re_path(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<slug>[\w-]+)/$', views.article_detail),
]

path()方法不同的在于两点:

  • year中匹配不到10000等非四位数字,这是正则表达式决定的
  • 传递给视图的所有参数都是字符串类型。而不像path()方法中可以指定转换成某种类型。在视图中接收参数时一定要小心。

4. 路由分发

当有很多个项目时,把所有url全写在一起会造成很大的麻烦

通常,我们会在每个app里,各自创建一个urls.py路由模块,然后从根路由出发,将app所属的url请求,全部转发到相应的urls.py模块中。

from django.contrib import admin
from django.urls import path, re_path, include
from blog import views
urlpatterns = [
path('admin/', admin.site.urls),
path('show_time/', views.show_time),
path('blog/', include('blog.urls')),
]
# /blog/urls.py
from django.urls import path, re_path
from blog import views
urlpatterns = [
re_path(r'^article/(\d{4})/(\d{2})/$', views.article),
re_path(r'^article/(?P<year>\d{4})/', views.get_article),
path('register/', views.register, name='reg'),
]

最新文章

  1. bzoj4750: 密码安全
  2. ubuntu下解决wireshark权限问题
  3. 标准C实现基于TCP/IP协议的文件传输
  4. QT对话框模式与非模式
  5. php怎么删除文件
  6. Warning: $HADOOP_HOME is deprecated.解决方法
  7. hadoop错误org.apache.hadoop.mapred.TaskAttemptListenerImpl Progress of TaskAttempt
  8. B-JUI(Best jQuery UI) 前端框架
  9. div图片垂直居中
  10. nmp install 异常
  11. Hexo 简明教程
  12. 【Android Studio安装部署系列】三十四、将Eclipse项目导入到Android Studio中
  13. 实时Cartographer测试(1) - rplidar
  14. 高级js--(面向对象js,arguments,闭包,自调)
  15. Golang 并发Groutine实例解读(一)
  16. 高速入门:十分钟学会Python
  17. 揭密FutureTask
  18. 使用Mac App Store更新、下载软件时出现未知错误的解决方法
  19. postgresql 数据库schema 复制
  20. Android 进阶10:进程通信之 Messenger 使用与解析

热门文章

  1. 在阿里云CentOS服务器上安装Python3.7并设置为默认Python
  2. ava 类似jest snapshot 功能试用
  3. 使用charles对jmeter进行抓包
  4. nginx 访问控制之 限速
  5. [2019BUAA软件工程]个人期末总结感想
  6. response.redirect 正在中止线程
  7. hue创建的hdfs数据在hdfs无法删除的问题。
  8. Supervisor进程守护工具的使用
  9. MQTT研究之EMQ:【EMQX使用中的一些问题记录(4)】
  10. Celery 服务搭建