Django之路由系统(URL)

29 篇文章 0 订阅
2 篇文章 0 订阅

URL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL模式以及要为该URL模式调用的视图函数之间的映射表;你就是以这种方式告诉Django,对于这个URL调用这段代码,对于那个URL调用那段代码。

在Django2.0以下的版本中,其格式为

urlpatterns = [ 
      url(正则表达式, views视图函数,参数,别名),
 ]

参数说明:

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

一、django的路由系统作用:

使views里面处理数据的视图函数(类)与请求的url建立映射关系。使请求到来之后,根据urls.py里的关系条目,去查找到与请求对应的处理方法,从而返回给客户端http页面数据。

二、正则表达式详解

在Django2.0以上的版本中需要from django.urls import re_path才能进行正则表达

from django.urls import path,re_path

其格式为

正则表达式的格式:r'^xxxx/$'

  • 正则表达式的开始使用“^”表示。
  • 正则表达式的结束使用“$”表示。
  • “r” 元字符串 防止正则表达式中的转义。
urlpatterns = [
    path('表达式',view视图函数,参数,别名),
    re_path('正则表达式',view视图函数,参数,别名)
]

一些常用的正则表达

  • [a-zA-Z]表示匹配所有英文字母中的任意一个字母
  • [0-9]表示任意一个数字
  • \d+表示前面的数字,出现一次或者多次
  • [0-9]{4}表示数字需要出现4次

最基础的URL映射

先从创建的app下的views.py面定义处理数据的函数
在urls.py里导入views
在urlpatterns里写入一条url与处理函数的l映射关系
url映射一般是一条正则表达式,“^” 字符串的开始,“$“ 字符串的结束
当写成”^$“时,不输入任何url时不会在返回黄页,而是返回后面函数里对应的页面。一般这一条会写在url的最后。如:
 

url(r'^$', views.index),

 urls.py 文件

from django.contrib import admin
from django.urls import path,re_path
from demo01 import views
urlpatterns = [
    re_path(r'^lawang4/$',views.laowang4),#匹配laowang4/路径
    re_path(r'$',views.laowang5),#匹配空路径 例如: http://127.0.0.1:8000
    re_path(r'lawang6/',views.laowang6),#不设置结尾,可以匹配多个路径 例如: http://127.0.0.1:8000/ee//egg
    re_path(r'[a-zA-Z][0-9]/$',views.laowang7)
    #[a-zA-Z]表示匹配所有英文字母中的任意一个字母
]    #[0-9]表示任意一个数字

views.py 文件

from django.shortcuts import render
#初始 正则
def laowang4(request):
    return render(request,'laowang4.html')
#匹配空路径
def laowang5(request):
    return render(request,'laowang5.html')
#匹配多个路径
def laowang6(request):
    return render(request,'laowang6.html')
#模糊匹配
def laowang7(request):
    return render(request,'laowang7.html')

 

三、正则表达式分组及分组命名匹配 

1.正则分组匹配:

格式:(正则内容)
正则表达式分组匹配是通过小括号”()”来捕获URL中的值并以位置参数形式传递给对应视图函数的位置参数。

视图函数接受的是内容时字符串类型。

urls.py文件

re_path(r'^laowang8/(\d+)/$',views.laowang8),

views.py文件 

def laowang8(request,num):
    print(num)
    return render(request,'laowang8.html')

2. 正则分组命名匹配:

分组命名正则表达式组的语法

(?P<name> pattern)

其中:

name是组的名称
pattern是要匹配的模式(正则内容)。
匹配成功后会将内容以关键词参数传递给对应的是视图函数,因此,视图函数的形参命名必须和正则分组匹配的’<名称>'相同。和先后顺序无关。

捕获的值作为 关键字参数 而不是位置参数传递给视图函数。
urls.py文件

re_path(r'^laowang9/(?P<year>[0-9]{4})/$',views.laowang9),
 re_path(r'^laowang10/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$',views.laowang10),

views.py文件

def laowang9(request,year):
    print(year)
    return render(request,'laowang9.html')

def laowang10(request,month,year):
    print(month)
    return render(request,'laowang10.html')

 起别名是为了如果需要更改正则表达式,那么所以的相关引用都需要更改,但是如果用别名作为引用,只要别名不便,其他地方也无需变动。

urlpatterns = [
    re_path('article/[0-9]{4}',views.article_year),
    #这种形式不会把参数传给视图函数
    re_path('article/([0-9]{4})',views.article_year),
    #当正则表达式加上括号时,会将匹配到的字符串传给视图函数,其形参可以任意
    re_path('article/(?P<year>[0-9]{4})',views.article_year),
    #(?P<name>)为匹配到的字符串命名,然后传给视图函数,且视图函数的形参必须是相应的name
]

其中正则表达式与之前一样,但是path还有用法,如

urlpatterns = [
    re_path('article/(?P<year>[0-9]{4}$)',views.article_year),
    path('article/<int:year>/<int:month>',views.article_month),
    path('article/<int:year>/<int:month>/<slug>',views.article_detail),
    path('register',views.register,name='reg')
]

基本规则:

  • 使用尖括号(<>)从url中捕获值。
  • 会将捕获到的值传给视图函数,形参必须与命名一样。
  • 捕获值中可以包含一个转化器类型(converter type),比如使用 <int:name> 捕获一个整数变量。若果没有转化器,将匹配任何字符串,当然也包括了 / 字符。
  • 无需添加前导斜杠。

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

  • str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式
  • int,匹配正整数,包含0。
  • slug,匹配字母、数字以及横杠、下划线组成的字符串。
  • uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。
  • path,匹配任何非空字符串,包含了路径分隔符

四、路由分发

实际上每个应用都应该有一个URLs文件来进行url配置,而不是都放在主目录的URLs中。

所以我们应该为每个应用创建相应的urls文件,导入在主目录的urls文件中include

from django.urls import path,re_path,include

以blog应用为例

urlpatterns = [
    path('admin/', admin.site.urls),
    path('show_time/',views.show_time),
    re_path('^blog/',include('blog.urls')),
]

注意最后一个表示所有blog相关的url配置都在自己的urls配置文件中查找。 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Y_Hungry

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值