Django之url路由
Django之url路由
url路由介绍
url路由是关联url及其视图函数关系的过程。
作用就是使views里面处理数据的函数与请求的url建立映射关系
url路由配置
Django的url路由配置在settings.py文件中ROOT_URLCONF变量指定全局路由文件名称。
注意:默认创建项目的时候,就会配置好,如果想使用别的配置文件自行修改。
Django的URL路由流程
- Django查找全局urlpatterns变量(urls.py)
- 按照先后顺序,对URL逐一匹配urlpatterns每个元素
- 找到第一个匹配时停止查找,根据匹配结果执行对应的处理函数。
- 如果没有找到匹配或出现异常,Django进行错误处理
urlpatterns
Django的路由都写在urls.py文件中的urlpatterns列表中,由path()或re_path()作为元素组成。 Urlpatterns中的path()处理字符串路由,re_path处理正则表达式路由。
urlpatterns的格式:
urlpatterns=[ path(route,views.函数名,向处理函数提供的额外参数,以字典形式表示,该URL模式的别名), re_path(正则表达式,view.对应的处理函数), ]
参数详解:
url()函数可以传递4个参数,其中2个是必须的:regex和view,以及2个可选的参数:kwargs和name。
下面是具体的解释: regex:正则表达式
性能注释:正则表达式会进行预先编译当URLconf模块加载的时候,因此它的匹配搜索速度非常快,你通常感觉不到。 view:对应的视图处理函数 kwargs:任意数量的关键字参数可以作为一个字典传递给目标视图。 name:对你的URL进行命名,可以让你能够在Django的任意处,尤其是模板内显式地引用它。相当于给URL取了个全局变量名,你只需要修改这个全局变量的值,在整个Django中引用
它的地方也将同样获得改变。这是极为古老、朴素和有用的设计思想,而且这种思想无处不在。
不同的route形式:
Django支持三种表达route: 1、 精确字符串格式:articles/2017/ 一个精确URL匹配一个操作函数;最简单的形式,适合对静态URL的响应;URL字符串不以“/”开头,但要以“/”结尾 2、 Django的转换格式:<类型:变量名>,articles/<int:year>/ 是一个URL模版,匹配URL同时在其中获得一批变量作为参数;是一种常用形式,目的是通过URL进行参数获取和传递 3、 正则表达式格式:articles/(?p<year>[0-9]{4})/
最基础映射
urls.py
from django.contrib import admin
from django.urls import path
from blog import views urlpatterns = [
path('articles/2017/', views.index1), ]
view.py
from django.shortcuts import render,HttpResponse
def index1(req):
return HttpResponse("index1")
访问http://127.0.0.1:8080/articles/2017/时页面返回:index
分组匹配
使用正则表达式获取url匹配结果,传给后端。有几个分组,就有几个参数。
urls.py
from django.contrib import admin
from django.urls import path
from django.urls import re_path
from blog import views urlpatterns = [
re_path("articles/(\d{4})/(\d{2})/", views.index2), ]
view.py
from django.shortcuts import render,HttpResponse
def index2(req,year,month):
return HttpResponse("index2:"+"%s,%s"%(year,month))
访问http://127.0.0.1:8080/articles/2017/12/时:返回index2:2017,12
分组命名匹配
也可以将匹配结果发给后端。但是指定分组名字后,参数名必须和分组名相同。
urls.py
from django.contrib import admin
from django.urls import path
from django.urls import re_path
from blog import views urlpatterns = [
re_path('articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/', views.index3), ]
view.py
from django.shortcuts import render,HttpResponse
def index3(req,year,month):
return HttpResponse("index3:"+"%s,%s"%(year,month))
访问http://127.0.0.1:8080/articles/2017/12时返回:index3:2017,12
注意:分组匹配和分组命名匹配两种方式不能混用
多个app分流
默认新建的app下面是没有路由模块urls.py,但是当网站结构增大的时候,我们需要将流量分开,即在每个应用下新建自己的路由模块。
工程/urls.py
from app01 import urls
url(r'^app01/', include(urls)) app01/urls.py # 二级路由模块
现在我们的全部放在全局的urls.py文件中
当我们的url匹配全部放在一个文件时,这样肯定可以,但是不方便
当我们的应用文件变多时,最好是把不同应用的url放在不同的应用文件的urls.py下,就是在每一个应用文件下都有一个url路由
不同的应用的url匹配互不影响
现在我们将以下这个全局的urls.py文件进行分发url配置:
from django.contrib import admin
from django.urls import path
from django.urls import re_path
from blog import views urlpatterns = [
path('admin/', admin.site.urls),
path('show_time/',views.show_time),
path('articles/2017/', views.index1),
re_path("articles/(\d{4})/(\d{2})/", views.index2),
re_path('articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/', views.index3), ]
全局的urls.py
from django.contrib import admin
from django.urls import path,include
from django.urls import re_path
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.contrib import admin
from django.urls import path,include
from django.urls import re_path
from blog import views
urlpatterns = [
#什么意思:只要以blog开头的url都给分发到blog.urls
path('articles/2017/', views.index1),
re_path("articles/(\d{4})/(\d{2})/", views.index2),
re_path('articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/', views.index3),
] 刚才没有在应用设置urls.py文件时,访问一个url直接在全局的urls.py下映射到视图函数
现在设置应用下的urls.py文件后,访问一个url,如:path('show_time/',views.show_time)就会匹配映射视图函数
如:path('blog/', include('blog.urls')),会到应用文件下的urls.py下去匹配url,然后映射给视图函数处理
注意:
原先:http://127.0.0.1:8080/articles/2019/12
现在:http://127.0.0.1:8080/blog/articles/2019/12/ (现在访问需要加上blog,因为先要匹配上blog目录,才能到blog下匹配url)
url反向解析
当urls.py文件中的路由改变时,导致网页需要重新修改。主要原因时跳转是根据路由来实现的,当页面中的<a href="..." >写死的时候,修改页面会导致出错。
本质上就是给url匹配模式起别名,然后用过别名拿到具体的URL路径。
下面我们演示一次用户注册页面::
理解:url反向解析
理解:Django的路由不考虑HTTP请求方式,仅根据URL进行路由,即只要URL相同,无论POST、GET等哪种请求方式都指向同一个操作函数。
html代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body> <form action="http://127.0.0.1:8080/register.html/" method="get" >
<p>文本框:<input type="text" name="username" placeholder="姓名"></p>
<p>密码框:<input type="password" name="passwd" placeholder=" 密码"></p>
<p>单选框:男<input type="radio" name="gender" value="men">女<input type="radio" name="gender" value="women"></p>
<p>复选框:音乐<input type="checkbox" name="hobby" value="music">电影<input type="checkbox" name="hobby" value="movice"></p>
<p>下拉输入项:
<select name="生日">
<option value=""></option>
<option value=""></option>
<option value=""></option>
</select>
</p>
<p>提交按钮:<input type="submit"></p>
<p>重置按钮:<input type="reset"></p> </form>
</body>
</html>
urls.py
from django.contrib import admin
from django.urls import path
from blog import views urlpatterns = [
path("register.html/",views.register),
]
view.py
def register(req):
print(req.GET)
if req.method=="POST":
print("success!")
return render(req,"register.html")
1.浏览器访问http://127.0.0.1:8080/register.html(第一次请求为get请求)
2.填写数据,提交数据(第二次请求为from表单的处理url)
3.在服务端查看数据
现在我们改变from表单提交方法为POST
然后注释django的setting文件下的MIDDLEWARE的这一下行
'django.middleware.csrf.CsrfViewMiddleware'
然后重新提交数据,你会发现会打印success
不管get还是post请求,都会教给对应的视图函数处理!!!
现在我们改变urls.py
path("register.html/",views.register)
path("register.html/",views.register,name="reg")
怎么使用?
先在<head>标签下加这一行代码:{% load staticfiles %}
在需要使用的地方:
<form action={% url 'reg' %} method="get" >
Django之url路由的更多相关文章
- Django 02 url路由配置及渲染方式
Django 02 url路由配置及渲染方式 一.URL #URL #(Uniform Resoure Locator) 统一资源定位符:对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示,是 ...
- 3/19 Django框架 url路由配置及模板渲染
3/19 Django框架 url路由配置及模板渲染 1.路由分配 URL(Uniform Resoure Locato):统一资源定位符是对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示, ...
- django中url路由配置及渲染方式
今天我们学习如何配置url.如何传参.如何命名.以及渲染的方式,内容大致有以下几个方面. 创建视图函数并访问 创建app django中url规则 捕获参数 路径转换器 正则表达式 额外参数 渲染方式 ...
- Django的URL路由系统
一. URL配置 URL配置就像Django所支撑网站的目录.它的本质是URL与要为该URL调用的视图之间的映射表.你就是以这种方式告诉Django,对于哪个URL调用的这段代码. 基本格式 from ...
- Django之URL路由系统
一 URL配置 Django 1.11版本 URLConf官方文档 URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表.你就是以这 ...
- Django之URL(路由系统)用法
路由系统 路由系统概念 简而言之,路由系统就是路径和视图函数的一个对应关系.django的路由系统作用就是使views里面处理数据的函数与请求的url建立映射关系.使请求到来之后,根据urls.py里 ...
- Django的URL路由基础
一.概述 URL路由在Django项目中的体现就是urls.py文件,这个文件可以有很多个,但绝对不会在同一目录下.实际上Django提倡项目有个根urls.py,各app下分别有自己的一个urls. ...
- Django( 学习第三部 Django的url路由层)
目录 url路由层 路由匹配(有名分组与无名分组) 反向解析 路由分发 名称空间(了解) Django版本区别 url 路由匹配 注意事项: url方法,第一个参数是正则表达式,只要第一个参数能够匹配 ...
- Django的URL路由
URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL模式以及要为该URL模式调用的视图函数之间的映射表:你就是以这种方式告诉Django,对于这个URL调用这段代码,对于那 ...
随机推荐
- 点击<a>标签后禁止页面跳至顶部
一.点击<a>标签后禁止页面跳至顶部 1. 使用 href="javascript:void(0);",例如: <a href="javascript: ...
- Linux永久修改IP地址
通常我们为了快速修改IP地址,会这么做 ifconfig eth0 192.168.0.2 netmask 255.255.255.0 这样修改IP地址后,你再运行ifconfig命令后,的确IP地址 ...
- Confluence 6 编辑一个站点装饰文件
希望编辑一个站点的 decorator 文件: 进入 > 基本配置(General Configuration) > 布局(Layouts )(在Look and Feel 菜单下面) ...
- 树形dp 入门
今天学了树形dp,发现树形dp就是入门难一些,于是好心的我便立志要发一篇树形dp入门的博客了. 树形dp的概念什么的,相信大家都已经明白,这里就不再多说.直接上例题. 一.常规树形DP P1352 没 ...
- android入门小结一
一 Android入门基础:从这里开始 gradle介绍: Android Studio使用Gradle 编译运行Android工程. 工程的每个模块以及整个工程都有一个build.gradle文件. ...
- 初识dubbo
1. 为什么需要 Dubbo(摘自http://dubbo.apache.org/zh-cn/docs/user/quick-start.html) 随着互联网的发展,网站应用的规模不断扩大,常规的垂 ...
- 在前台根据传过来的XX级别的数字转XX的名字
需求描述:进入页面,展示列表,列表中有个XX级别的项,数据库中的级别使用1234来存放的,现在要转成对应的一级XX,二级XX,三级XX,四级XX. 吐槽一下:正常的做法应该是在后台,就把查出来的级别1 ...
- 【ES】学习10-聚合3
聚合是在查询匹配的文档中做统计的 不指定查询语句时,从所有文档中匹配. 下面两个语句等价: GET /cars/transactions/_search { , "aggs" : ...
- Python基础之模块与包
一.模块 1.什么是模块? 一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 2.为何要使用模块? 如果你退出python解释器然后重新进入,那么你之前定义的函 ...
- mysql 去除重复 Select中DISTINCT关键字的用法 在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是 distinct只能返回它的目标字段,而无法返回其它字段,这个问题让我困扰了很久,用distinct不能解决的话,
在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供 有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记 ...