路由分发决定哪一个路由由哪一个视图函数来处理。

注意:django2.0里的re_path和django1.0里的url除了名字不一样,其他都一样。

简单配置

  1. from django.urls import path,re_path
  2.  
  3. from app01 import views
  4. urlpatterns = [
  5. path('admin/', admin.site.urls),
  6. path('timer/',views.timer),
  7.  
  8. # 路由配置: 决定哪一个路由由哪一个视图函数来处理
  9. # repath和django1.0里的url用法一样
  10. # 不写^,articles前面可以写任何东西(edward/123/articles);同理,不写$,2003后面也可以写任何东西。
  11. re_path(r'^articles/2003/$',views.special_case_2003),
  12.  
  13. # 正则匹配年份
  14. # 如果是2003,会匹配第一个
  15. # 如果去掉$就不走第三个了,因为匹配到年份那就不往后匹配了,而是直接执行arvhive_year了。
  16. re_path(r'^articles/([0-9]{4})/$',views.archive_year), # year_archive(request,1999)。django2.1.5不用传第二个参数了
  17.  
  18. re_path(r'^articles/([0-9]{4})/([0-9]{2})/$',views.month_archive),
  19.  
  20. # re_path(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<day>[0-9]{2})/$', views.article_detail),
  21. ]

注意:

  • 若要从URL 中捕获一个值,只需要在它周围放置一对圆括号。

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

  • 每个正则表达式前面的'r' 是可选的但是建议加上。它告诉Python 这个字符串是“原始的” —— 字符串中任何字符都不应该转义

有名分组

  1. # urls
  2. # 有名分组,?P<year>相当于是起了个名字,然后把名字当做参数传给视图函数,后面才是正则部分。
  3. re_path(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$',views.month_archive),
  4. '''
  5. month_archive(request,year=2009,momth=12)
  6. 这样在views视图,不管传入的参数的顺序是什么,year就是year,month就是month,但是名字必须是year和month
  7. '''
  8.  
  9. #views
  10. def month_archive(request, month,year): # 顺序颠倒也没有问题,不管顺序是什么都会正常显示year和month
  11. return HttpResponse('year:%s,month:%s' % (year,month))

路由分发

在app01下面重新创建一个urls的文件,把关于app01的url放到里面,然后再在公共项目的urls里导入app01的urls

  1. # app01 urls.py
  2. from django.urls import path, re_path
  3.  
  4. from app01 import views
  5.  
  6. urlpatterns = [。
  7. re_path(r'^articles/2003/$', views.special_case_2003),
  8. re_path(r'^articles/([0-9]{4})/$', views.archive_year), # year_archive(request,1999)。
  9. re_path(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.month_archive),
  10. ]
  11.  
  12. # demo urls.py
  13. urlpatterns = [
  14. path('admin/', admin.site.urls),
  15. path('timer/', views.timer),
  16.  
  17. # 分发:
  18. re_path(r'^app01', include('app01.urls')),
  19. # re_path(r'^', include('app01.urls') # 路径里面不用写app01了
  20. ]

反向解析

反向解析就是给url起一个别名,我们用别名去找这个url就行,这样不管url如何改变,我们都可以用别名找到它。

1. 在模板中进行反向解析

urls.py

  1. from django.urls import path, re_path, include
  2.  
  3. from app01 import views
  4.  
  5. urlpatterns = [
  6. path('admin/', admin.site.urls),
  7. path('timer/', views.timer),
  8. path('login.html/',views.login,name='Log'),
  9.  
  10. # 分发:
  11. re_path(r'^', include('app01.urls')),
  12. ]

login.html

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Login</title>
  6. </head>
  7. <body>
  8.  
  9. <!-- 在render的时候,去urls里找一个name叫Log的url,这样action里永远都是最新的url -->
  10. <form action="{% url 'Log' %}" method="post">
  11. 用户名 <input type="text" name="user">
  12. 密码 <input type="password" name="pwd">
  13. <input type="submit">
  14. </form>
  15.  
  16. </body>
  17. </html>

2. 在视图函数里进行反向解析

  1. # app01 urls
  2.  
  3. re_path(r'^articles/2003/$', views.special_case_2003,name ='s_c_2003'),
  4. re_path(r'^articles/([0-9]{4})/$', views.archive_year,name='y_a'),
  5.  
  6. from django.urls import reverse
  7. def special_case_2003(request):
  8. url = reverse('s_c_2003') # 不需要参数,因为不含正则是一个完整的url,找到后直接匹配
  9. url2 = reverse('y_a',args=(4009,)) # ^articles/([0-9]{4})/ 需要给一个四位数字的参数,匹配正则,参数可以是任意四位数字,具体数字按需求写。
  10. print(url) # /articles/2003/
  11. print(url2) # /articles/4009/
  12. return HttpResponse("<h3>special_case_2003</h3>") # HttpResponse里面写的是响应体的内容

命名空间

主项目 urls.py

  1. from django.urls import path, re_path, include
  2.  
  3. from app01 import views
  4.  
  5. urlpatterns = [
  6. path('admin/', admin.site.urls),
  7. path('timer/', views.timer),
  8. path('login.html/', views.login, name='Log'),
  9.  
  10. # 分发:
  11. # 命名空间不可以重名
  12. re_path(r'^app01', include(('app01.urls', 'app01'))),
  13. re_path(r'^app02', include(('app02.urls', 'app02'))),
  14. ]

app01

  1. # urls
  2. re_path('index/',views.index,name='index')
  3.  
  4. # views
  5. def index(request):
  6.  
  7. # return HttpResponse(reverse('index')) # 找到的也是app02的index,用名称空间解决这个问题。
  8.  
  9. # 用命名空间解决
  10. return HttpResponse(reverse('app01:index')) # # 冒号之前是namespace,冒号之后是名字

app02

  1. # urls
  2. re_path('index/',views.index,name='index')
  3.  
  4. # views
  5. def index(request):
  6.  
  7. # return HttpResponse(reverse('index')) # 找到的app02的index,用命名空间解决名字冲突的问题
  8.  
  9. return HttpResponse(reverse('app02:index'))

path方法(django2.0)

re_path有两个问题:

1.不能进行字符转换。

  1. def month_archive(request, month, year):
  2. print(type(month)) # str
  3. print(type(year)) # str
  4. return HttpResponse('year:%s,month:%s' % (year, month))

2.同样的正则表达式,需要写多遍,不易于维护。

  1. urlpatterns = [
  2. re_path('articles/(?P<year>[0-9]{4})/', year_archive),
  3. re_path('article/(?P<article_id>[a-zA-Z0-9]+)/detail/', detail_view),
  4. re_path('articles/(?P<article_id>[a-zA-Z0-9]+)/edit/', edit_view),
  5. re_path('articles/(?P<article_id>[a-zA-Z0-9]+)/delete/', delete_view),
  6. ]

而path可以解决这两个问题

  1. # urls
  2. from django.urls import path
  3. path('articles/<int:year>',views.path_year)
  4.  
  5. #views
  6. def path_year(request,year):
  7. print(type(year)) # int
  8. return HttpResponse('path year')

基本规则:

  • 使用尖括号(<>)从url中捕获值。

  • 捕获值中可以包含一个转化器类型(converter type),比如使用 <int:name> 捕获一个整数变量。若果没有转化器,将匹配任何字符串,当然也包括了 / 字符。

  • 无需添加前导斜杠。

path转换器

Django默认支持以下5个转化器:

  • str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式

  • int,匹配正整数,包含0。

  • slug,匹配字母、数字以及横杠、下划线组成的字符串。

  • uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。

  • path,匹配任何非空字符串,包含了路径分隔符

自定义path转换器

在实际开发中,django自带的转换器是不能满足我们的需求的,这就需要自定义转换器了

操作步骤:

1.在app里创建一个类,写自定义转换的规则

url_convert.py

  1. class MonConvert:
  2. regex = "[0-9]{2}" # 只能叫regex
  3.  
  4. def to_python(self, value):
  5. return int(value) # 不转化就是字符串,可以根据需求做任何操作。
  6.  
  7. def to_url(self, value): # 用于反向解析
  8. return "%04d" % value

2.在urls里注册自定义转换器

  1. from django.urls import path, re_path, include,register_converter
  2. from app01.url_convert import MonConvert
  3.  
  4. # 注册自定义转换器
  5. register_converter(MonConvert,'mm')

3.在路由分发里使用自定义转换器

  1. urlpatterns = [
  2. path('articles/<mm:month>',views.path_month),
  3. ]

Registering custom path converters

For more complex matching requirements, you can define your own path converters.

A converter is a class that includes the following:

  • regex class attribute, as a string.
  • to_python(self, value) method, which handles converting the matched string into the type that should be passed to the view function. It should raise ValueError if it can’t convert the given value.
  • to_url(self, value) method, which handles converting the Python type into a string to be used in the URL.

django之路由分发的更多相关文章

  1. Django之路由分发系统

    web的基本工作流程 首先,我们先来思考一下我们平常在上网浏览网页时候的场景,大致就是打开一个web浏览器,输入某一个网站的地址,然后转到该网址,在浏览器中得到该网址的页面.从这个场景中我们可以抽象出 ...

  2. Django之路由分发和反向解析

    一.路由分发: 路由分发是指:总路由不再直接做路由与视图函数的对应关系,而是将获取的路由分发给下面的app去处理对应关系 from django.conf.urls import url,includ ...

  3. Django之路由分发反向解析

    Django路由分发|反向解析 当一个Django中有多个app时,路由会有很多,将这些路由都写在与项目同名的文件夹下就会显得很多,很乱.并且在协同开发的时候容易出现相同的命名,当项目合并后就会出现路 ...

  4. Django的路由分发与名称空间

    路由分发 django每一个app下面都可以有自己的urls.py路由层,templates文件夹,static文件夹 项目名下urls.py(总路由)不再做路由与视图函数的匹配关系而是做路由的分发 ...

  5. Django框架路由分发-名称空间

    目录 一:路由分发 1.路由分发简介 2.总路由分发配置 3.总路由终极配置(不需要导应用路由,直接点应用即可) 4.子路由配置 二:名称空间 1.名称空间应用场景 3.解决方式二>>&g ...

  6. Django学习之十一:真正理解Django的路由分发和反解url原理

    目录 URL Dispatcher 简介 模式概念 对比URLPattern 与 URLResolver (多态的体现) 构建子路由几种方式 反解url算法逻辑 URL Dispatcher 简介 d ...

  7. $Django 路由层(有,无名分组、反向解析、总路由分发、名称空间、伪静态)

    1 简单配置 -第一个参数是正则表达式(如果要精准匹配:'^publish/$')  -第二个参数是视图函数(不要加括号)  -url(r'^admin/', admin.site.urls), 注: ...

  8. django 路由分发

    对于一个大的工程,可能会有很多应用,比如cmbd,moniter,openstack等等,我们就要用到路由分发 1,首先在跟工程同名的文件夹下的urls中写分发表: from django.conf. ...

  9. Django学习手册 - 正则URL路由配置/路由分发

    ############################################### 总结: 一.url路由配置: 方式一:(通过url链接get获取) 方式二:(url路由匹配方式获取-拓 ...

随机推荐

  1. c#写word文档基础操作(自己控制样式)

    下面一个函数,建立一个Word 文档,添加页眉.页脚,在内容中两个不同字体的Hello!!!   来自 <http://bbs.csdn.net/topics/340041961> pub ...

  2. 使用Foxfly.Net读取STEP文件

    Foxfly.Net是具备基本的几何建模和CAD文件读取功能.本文主要介绍读取STP/STEP文件的使用方法. 1.初始化 项目中引入FoxflyNet.dll程序集,在Program.cs中初始化建 ...

  3. 一些C/C++中的函数

    项目中使用到的C/C++中的一些函数,记录下来加以理解和掌握. 1.memset( ) memset是计算机中C/C++语言函数.将s所指向的某一块内存中的前n个 字节的内容全部设置为ch指定的ASC ...

  4. Unity中的输入

    目录 移动平台的输入 触摸 触摸相关的函数 触摸的一个示例 重力加速器 在Unity中访问重力加速器的信息 重力加速器示例 虚拟键盘 其他输入 传统的输入 鼠标,键盘,控制杆,手柄 虚拟控制轴(Vir ...

  5. 关于前端的交互 ajax

    对于交互来说,可以利用原生的javascript和jquery 这篇说的就是jquery 1 不是跨域的 利用$ajax({})这个函数实现的 $.ajax({ url: "", ...

  6. 让SAP云平台上的Web应用使用destination服务

    首先在SAP云平台里创建一个destination,维护service的end point: 然后打开SAP云平台的WebIDE,创建一个新的文件夹和新的HTML5 Application Descr ...

  7. 奇怪的Unrooted Tests错误

    错误如图: 条件如下: Eclipse里的Maven工程. 使用JUnit4(这个是否必须不知,反正我的工程用的4) 修改某个Test类里的方法名,或者增加一个Test方法. 现象: 在MyEclip ...

  8. Android(java)学习笔记154:采用HttpClient提交数据(qq登录案例)

    1.Apache -Httpclient HttpClient 是 Apache Jakarta Common 下的子项目,可以用来提供高效的.最新的.功能丰富的支持 HTTP 协议的客户端编程工具包 ...

  9. CSS布局--垂直水平居中

    ···设置两个盒子 <div class="parent"> <div class="child"> </div></ ...

  10. BZOJ 2502: 清理雪道

    BZOJ 2502: 清理雪道 标签(空格分隔): OI-BZOJ OI-最小流 OI-上下界网络流 Time Limit: 10 Sec Memory Limit: 128 MB Descripti ...