URL路由映射
一、概要
路由映射模块,主要完成url与views视图函数的映射。当一个url请求到来时,会按照这个模块中的url地址从上到下进行匹配,如果匹配成功,将执行映射试图中的函数;反之将返回404错误'
二、匹配基本流程
- 说明
根据HTTP请求中的URL,查找路由表,将HTTP请求分发到 不同的视图去处理 -
示例图
三、基本介绍
1、基本语法
- Django 1.7.x以下版本
from django.conf.urls import patterns, include, url from django.contrib import admin urlpatterns = patterns( url(正则表达式, 'view函数',参数,别名), url(r'^admin/', include(admin.site.urls)), )
- Django 1.8.x - Django 2.0 版本
from django.conf.urls import url from django.contrib import admin from views import home urlpatterns = [ url(正则表达式,view函数,参数,别名), url(r'^admin/'c, admin.site.urls), url(r'^index/', home.index), ]
- Django 2.0 版本(兼容1.8以上)
from django.contrib import admin from django.urls import path from views import home urlpatterns = [ path(正则表达式, view函数名,参数,别名), path('admin/', admin.site.urls), path(r'^index/', home.index), ]
2、url详解
- 语法格式
url(正则表达式, view函数名,参数,别名),
- 参数说明
- regex: 必要参数,是正则表达式的通用缩写
- view:必要参数,
可以是视图函数名,也可以是include函数 - kwargs:
任意数量的关键字参数可以作为一个字典传递给目标视图。 - name:
对你的URL进行命名,可以让你能够在Django的任意处,通常是在模板内显式地引用它。也可以在配合reverse函数进行反向解析
四、示例代码
1、基本的配置
- 说明
在项目的同名目录下的urls.py文件中映射 - 举个栗子
from django.conf.urls import url, include # 正则表达式的最前面的r表示raw_string 原生字符串。 urlpatterns = [ # 字符串匹配 url(r'hello/', views.hello), # 正则匹配 url(r'^t[a-z]+/$', views.test), ]
2、动态路由
- 说明
所有的动态路由就是在浏览器输入的网址的时候后面的路径的动态的,参数按照顺序传递给views里面相对应的函数 - 举个栗子
urlpatterns = [ url(r'^list/(\d+)/(\d+)/$', views.list), ] # views def list(req, page, size): return HttpResponse('当前第%s页,默认%s条数' % (page, size)) # 访问路径 http://127.0.0.1:8000/route/list/1/10/
3、关键字动态路由
- 说明
利用正则表达式的分组方法,将url以参数的形式传递到函数,可以不按顺序排列,但视图函数中定义的参数名必须和路由中正则表达式中的名称一致,否则报错 - 举个栗子
# (?p<分组名>正则语法) urlpatterns = [ url(r'^param_list/(?P<uid>\d+)/$', views.param_list), ] #,相当于一个字典, key=uid, value=\d+。 {"uid":"\d+"} # views.py def param_list(req, uid): return HttpResponse('用户名id%s' % uid) #访问路径 http://127.0.0.1:8000/route/param_list/1/
4、二级路由
- 说明
那如果映射 url 太多怎么办,全写一个在 urlpatterns 显得繁琐,我们可以在每个app下新建urls文件,如何在根目录中使用include
导入 - 举个栗子
# 项目根目录的 urls.py urlpatterns = [ url(r'^test/$', views.test), url(r'^test1/$', views.test1), url('user/$', include('user.urls'), ] # 在 user app的urls.py urlpatterns = [ url('logoin/$', views.login), ] # 注意访问路径是一级路由(项目根目录的urls中定义的) + 二级路由 # http://127.0.0.1:8000/user/logoin/
5、name参数的使用
- 说明
url中还支持name参数的配置,如果配置了name属性,在模板的文件中就可以使用name值来代替相应的url值 - 举个栗子
# urls.py urlpatterns = [ url(r'^index',views.index,name='bieming') ] # 模板中 <form action="{% url 'bieming' %}" method="post"> </form>