一、URL

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

urlpatterns = [
url(正则表达式, views视图函数,参数,别名),
]
别名 name="reg" ,跟 标签 {% url "reg" %} 配合使用,意味着中国url 指向 别名代表的那个 url匹配。
    这个 url 标签 有好几种情况用法,在 2.1 版本,【加参数,{% url 'bieming' {{ canshu }} %}】
      【url.py 别名重名 https://docs.djangoproject.com/zh-hans/2.1/intro/tutorial03/

参数说明:

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

二、例子

url(r'^index.html/(\d+)/(\w+)', views.index),

def index(request,a,b):
print(request.GET)
print(a)
print(b)
return HttpResponse(a+" "+b) URL里有 无名分组匹配时候,会给 views 函数 位置传参 [15/Sep/2019 14:56:21] "GET /index.html/123/qwe HTTP/1.1" 200 8
<QueryDict: {}>
123
qwe =========================== url(r'^index1.html/(?P<year>\d{4})/(?P<month>\d{2})', views.index1 ), def index1(request,month,year):
print(request.GET)
print("year",year)
print("month",month)
return HttpResponse("year:{} month:{}".format(year,month)) URL里的有名分组,匹配到后给views函数 关键字传参,相当于在URL()的参数位置写上匹配到的字典。比如下面的例子
<QueryDict: {}>
[15/Sep/2019 14:59:01] "GET /index1.html/2020/03 HTTP/1.1" 200 18
year 2020
month 03 ========================== url(r'^index3.html/(?P<year>\d+)', views.index3 ,{"name":"qweqwe","age":12}), def index3(request,year,age,name):
print(request.GET)
print("year",year)
print("name",name)
print("age",age)
return HttpResponse(year) 当匹配到这个URL时候,会将有名分组 year +到后面的字典里, [15/Sep/2019 15:02:16] "GET /index3.html/2020 HTTP/1.1" 200 4
year 2020
name qweqwe
age 12 ============================== url(r'^index2.html$', views.index2), def index2(request):
print(request.GET)
aa = request.GET.get("aa")
print(aa)
return HttpResponse(aa) 【http://127.0.0.1:8888/index2.html?aa=213】
请求的URL是带有传参的,这种传参是赋值给 get方法 <QueryDict: {'aa': ['']}>
[15/Sep/2019 15:11:53] "GET /index2.html?aa=213 HTTP/1.1" 200 3
213

三、路由分发

  存在将不同URL分类到不同的APP中再处理,采取路由分发

在  项目的 urls.py 文件
导入 include
from django.conf.urls import url,include url(r'^app01', include("app01.urls")), 在 APP01 下创建 urls.py 文件
所有app01 的请求就转到 APP01 下的 urls.py 文件 做URL处理。
APP01  下的 urls.py 文件
from django.conf.urls import url,include
from app01 import views
urlpatterns = [
url(r'/index.html', views.index4),
url(r'/register', views.register),
]

views.py 的函数

def index4(request):

    return render(request,"index.html")

def register(request):
print("post ",request.POST) return HttpResponse("ok111")

模板文件【HTML】的 form表单 , post 请求

<h1>学生注册</h1>
<form action="/app01/register" method="post">
{% csrf_token %} {# post 请求 加这个 #}
<p>姓名 <input type="text" name="user"></input></p>
<p>年龄 <input type="text" name="age"></input></p>
<p>爱好
<input type="checkbox" name="hobby" value="1">足球</input>
<input type="checkbox" name="hobby" value="2">篮球</input>
<input type="checkbox" name="hobby" value="3">乒乓球</input>
</p>
<p><input type="submit" >提交</p>
</form>

最后 在 后台打印

post  <QueryDict:
{
  'csrfmiddlewaretoken': ['qzqavNxXMQtYzbNdUUa1mfZp6GpqU3tCCYlvJQUWLhd0mJ3gxpsTYDKR0P3biwrr'],
  'user': ['qwe'],
  'age': ['2'],
  'hobby': ['1']
}
>

如果改成 get 请求, 那么 会在URL地址栏 看到提交后的 URL是把 提交的参数显示出来了,

chome 开发者模式 也能看到

Request URL: http://127.0.0.1:8888/app01/register?user=qwe&age=2222222222&hobby=3
Request Method: GET
Status Code: 200 OK
Remote Address: 127.0.0.1:8888
Referrer Policy: no-referrer-when-downgrade

后台打印

<QueryDict:
{
'user': ['qwe'],
'age': [''],
'hobby': ['']}
>
这个 就没有 token 了

四、视图函数  views

http请求中产生两个核心对象:

http请求:HttpRequest对象

http响应:HttpResponse对象

所在位置:django.http

之前我们用到的参数request就是HttpRequest    检测方法:isinstance(request,HttpRequest)

HttpRequest对象的属性和方法:

# path:       请求页面的全路径,不包括域名
#
# method: 请求中使用的HTTP方法的字符串表示。全大写表示。例如
#
# if req.method=="GET":
#
# do_something()
#
# elseif req.method=="POST":
#
# do_something_else()
#
# GET: 包含所有HTTP GET参数的类字典对象
#
# POST: 包含所有HTTP POST参数的类字典对象
#
# 服务器收到空的POST请求的情况也是可能发生的,也就是说,表单form通过
# HTTP POST方法提交请求,但是表单中可能没有数据,因此不能使用
# if req.POST来判断是否使用了HTTP POST 方法;应该使用 if req.method=="POST"
#
#
#
# COOKIES: 包含所有cookies的标准Python字典对象;keys和values都是字符串。
#
# FILES: 包含所有上传文件的类字典对象;FILES中的每一个Key都是<input type="file" name="" />标签中name属性的值,FILES中的每一个value同时也是一个标准的python字典对象,包含下面三个Keys:
#
# filename: 上传文件名,用字符串表示
# content_type: 上传文件的Content Type
# content: 上传文件的原始内容
#
#
# user: 是一个django.contrib.auth.models.User对象,代表当前登陆的用户。如果访问用户当前
# 没有登陆,user将被初始化为django.contrib.auth.models.AnonymousUser的实例。你
# 可以通过user的is_authenticated()方法来辨别用户是否登陆:
# if req.user.is_authenticated();只有激活Django中的AuthenticationMiddleware
# 时该属性才可用
#
# session: 唯一可读写的属性,代表当前会话的字典对象;自己有激活Django中的session支持时该属性才可用。 #方法
get_full_path(), 比如:http://127.0.0.1:8000/index33/?name=123 ,req.get_full_path()得到的结果就是/index33/?name=123
req.path:/index33

  注意一个常用方法:request.POST.getlist('')

HttpResponse对象:

对于HttpRequest对象来说,是由django自动创建的,但是,HttpResponse对象就必须我们自己创建。每个view请求处理方法必须返回一个HttpResponse对象。

HttpResponse类在django.http.HttpResponse

在HttpResponse对象上扩展的常用方法:

页面渲染:         render()(推荐)
页面跳转: redirect("路径")
locals(): 可以直接将函数中所有的变量传给模板

  

URL 路由系统 + views 函数的更多相关文章

  1. URL路由系统-命名空间

    命名空间 1.工程Django下的urs.py from django.conf.urls import url,include from django.urls import path,re_pat ...

  2. python django基础二URL路由系统

    URL配置 基本格式 from django.conf.urls import url #循环urlpatterns,找到对应的函数执行,匹配上一个路径就找到对应的函数执行,就不再往下循环了,并给函数 ...

  3. day 66 Django基础二之URL路由系统

    Django基础二之URL路由系统   本节目录 一 URL配置 二 正则表达式详解 三 分组命名匹配 四 命名URL(别名)和URL反向解析 五 命名空间模式 一 URL配置 Django 1.11 ...

  4. day 53 Django基础二之URL路由系统

    Django基础二之URL路由系统   本节目录 一 URL配置 二 正则表达式详解 三 分组命名匹配 四 命名URL(别名)和URL反向解析 五 命名空间模式 一 URL配置 Django 1.11 ...

  5. Django的URL路由系统

    一. URL配置 URL配置就像Django所支撑网站的目录.它的本质是URL与要为该URL调用的视图之间的映射表.你就是以这种方式告诉Django,对于哪个URL调用的这段代码. 基本格式 from ...

  6. Django之URL路由系统

    一 URL配置 Django 1.11版本 URLConf官方文档 URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表.你就是以这 ...

  7. Django之URL(路由系统)用法

    路由系统 路由系统概念 简而言之,路由系统就是路径和视图函数的一个对应关系.django的路由系统作用就是使views里面处理数据的函数与请求的url建立映射关系.使请求到来之后,根据urls.py里 ...

  8. url 路由系统

    Django的路由系统 URL配置(URLconf)就像Django所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表. 我们就是以这种方式告诉Django,遇到哪个URL的时 ...

  9. Django基础二之URL路由系统

    一 URL配置 Django 1.11版本 URLConf官方文档 URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表.你就是以这 ...

随机推荐

  1. LVM 在线扩容磁盘(ubuntu 14.04 server)

    mware workstation 8 或者 vmware vsphere client 6.0( exsi 6.0) (前提:你的服务器需要有已经存在的卷组,才可以添加新的物理卷到卷组,然后再扩容逻 ...

  2. 01-CSS3-justify-content: space-around; justify-content: space-between;

    /* justify-content: space-around; 运用在父级元素上 第一个子元素距离左边的距离==最后一个子元素距离右边的距离 除第一个子元素和最后一个子元素外,第2个,第3个... ...

  3. C++中的异常处理(上)

    C++内置了异常处理的语法元素try... catch ...-try语句处理正常代码逻辑-catch语句处理异常情况-try语句中的异常由对应的catch语句处理 try { ,); } catch ...

  4. SQL(二)语法

    数据库表 一个数据库通常包含一个或多个表.每个表有一个名字标识(例如:"Websites"),表包含带有数据的记录(行). 在本教程中,我们在 MySQL 的 RUNOOB 数据库 ...

  5. 如何在类中根据枚举值,获取枚举的message的工具类

    枚举类为: public enum OrderStatusEnum implements CondeEnum{ NEW(0, "新订单"), FINISHED(1, "完 ...

  6. day67_10_11

    一.路由跳转 在vue中,路由条状有很多种. 其中有点击事件触发的路由跳转: this.$router.push('/course'); 和通过名字跳转的: this.$router.push({na ...

  7. day56_9_20orm中的关键字段,orm查询13方法整合,查询优化和事务。

    一.常用字段. 在orm中有一些字段是常用字段: 1.AutoField 这个字段是自增的,必须填入参数primary_key=True,也就是说这个字段是表的主键,如果表类中没有自增列,就会自动创建 ...

  8. day47_9_6(前端之js)

    一.js发展. 1996年11月,JavaScript的创造者--Netscape公司,决定将JavaScript提交给国际标准化组织ECMA,希望这门语言能够成为国际标准.次年,ECMA发布262号 ...

  9. CF1221G Graph And Number(容斥,搜索,FMT)

    至今觉得这场 edu 的 G 比 EF 都要简单-- 不知道为什么出题人要把 \(m=0\) 放进去,先特判掉. 要求至少一个 \(0\),至少一个 \(1\),至少一个 \(2\),容斥一波,变成总 ...

  10. 线性结构之习题选讲-ReversingLinkedList

    目录 一.什么是抽象的链表 二.单链表的逆转 三.测试数据 3.1 边界测试 更新.更全的<数据结构与算法>的更新网站,更有python.go.人工智能教学等着你:https://www. ...