2.3 视图系统

一个视图函数(类),简称视图,是一个简单的Python 函数(类),它接受Web请求并且返回Web响应。

响应可以是一张网页的HTML内容,一个重定向,一个404错误,一个XML文档,或者一张图片。

无论视图本身包含什么逻辑,都要返回响应。代码写在哪里也无所谓,只要它在你当前项目目录下面。除此之外没有更多的要求了——可以说“没有什么神奇的地方”。为了将代码放在某处,大家约定成俗将视图放置在项目(project)或应用程序(app)目录中的名为views.py的文件中。

2.3.1 一个简单的视图函数

下面是一个以HTML文档的形式返回当前日期和时间的视图:

  1. from django.http import HttpResponse
  2. import datetime
  3.  
  4. def current_datetime(request):
  5. now = datetime.datetime.now()
  6. html = "<html><body>It is now %s.</body></html>" % now
  7. return HttpResponse(html)

让我们来逐行解释下上面的代码:

  • 首先,我们从 django.http模块导入了HttpResponse类,以及Python的datetime库。

  • 接着,我们定义了current_datetime函数。它就是视图函数。每个视图函数都使用HttpRequest对象作为第一个参数,并且通常称之为request

    注意,视图函数的名称并不重要;不需要用一个统一的命名方式来命名,以便让Django识别它。我们将其命名为current_datetime,是因为这个名称能够比较准确地反映出它实现的功能。

  • 这个视图会返回一个HttpResponse对象,其中包含生成的响应。每个视图函数都负责返回一个HttpResponse对象。

Django使用请求和响应对象来通过系统传递状态。

当浏览器向服务端请求一个页面时,Django创建一个HttpRequest对象,该对象包含关于请求的元数据。然后,Django加载相应的视图,将这个HttpRequest对象作为第一个参数传递给视图函数。

每个视图负责返回一个HttpResponse对象。

2.3.2 CBV和FBV

我们之前写过的都是基于函数的view,就叫FBV。还可以把view写成基于类的。

就拿我们之前写过的添加班级为例:

FBV版:

  1. # FBV版添加班级
  2. def add_class(request):
  3. if request.method == "POST":
  4. class_name = request.POST.get("class_name")
  5. models.Classes.objects.create(name=class_name)
  6. return redirect("/class_list/")
  7. return render(request, "add_class.html")

CBV版:

  1. # CBV版添加班级
  2. from django.views import View
  3.  
  4. class AddClass(View):
  5.  
  6. def get(self, request):
  7. return render(request, "add_class.html")
  8.  
  9. def post(self, request):
  10. class_name = request.POST.get("class_name")
  11. models.Classes.objects.create(name=class_name)
  12. return redirect("/class_list/")

注意:

使用CBV时,urls.py中也做对应的修改:

  1. # urls.py中
  2. url(r'^add_class/$', views.AddClass.as_view()),

2.3.3 Request对象和Response对象

request对象

当一个页面被请求时,Django就会创建一个包含本次请求原信息的HttpRequest对象。
Django会将这个对象自动传递给响应的视图函数,一般视图函数约定俗成地使用 request 参数承接这个对象。

官方文档

请求相关的常用值

  • path_info     返回用户访问url,不包括域名
  • method        请求中使用的HTTP方法的字符串表示,全大写表示。
  • GET              包含所有HTTP  GET参数的类字典对象
  • POST           包含所有HTTP POST参数的类字典对象
  • body            请求体,byte类型 request.POST的数据就是从body里面提取到的

属性

所有的属性应该被认为是只读的,除非另有说明。

request属性相关

上传文件示例

上传文件示例代码

方法

请求相关方法

注意:键值对的值是多个的时候,比如checkbox类型的input标签,select标签,需要用:

  1. request.POST.getlist("hobby")

2.3.4 Response对象

与由Django自动创建的HttpRequest对象相比,HttpResponse对象是我们的职责范围了。我们写的每个视图都需要实例化,填充和返回一个HttpResponse。

HttpResponse类位于django.http模块中。

使用

传递字符串

  1. from django.http import HttpResponse
  2. response = HttpResponse("Here's the text of the Web page.")
  3. response = HttpResponse("Text only, please.", content_type="text/plain")

设置或删除响应头信息

  1. response = HttpResponse()
  2. response['Content-Type'] = 'text/html; charset=UTF-8'
  3. del response['Content-Type']

属性

HttpResponse.content:响应内容

HttpResponse.charset:响应内容的编码

HttpResponse.status_code:响应的状态码

2.3.5 JsonResponse对象

JsonResponse是HttpResponse的子类,专门用来生成JSON编码的响应。

  1. from django.http import JsonResponse
  2.  
  3. response = JsonResponse({'foo': 'bar'})
  4. print(response.content)
  5.  
  6. b'{"foo": "bar"}'

默认只能传递字典类型,如果要传递非字典类型需要设置一下safe关键字参数。

  1. response = JsonResponse([1, 2, 3], safe=False)

2.3.6 Django shortcut functions

官方文档

render()

结合一个给定的模板和一个给定的上下文字典,并返回一个渲染后的 HttpResponse 对象。

  1. 参数:
  2. request 用于生成响应的请求对象。
  3.  
  4. template_name:要使用的模板的完整名称,可选的参数
  5.  
  6. context:添加到模板上下文的一个字典。默认是一个空字典。如果字典中的某个值是可调用的,视图将在渲染模板之前调用它。
  7.  
  8. content_type:生成的文档要使用的MIME类型。默认为 DEFAULT_CONTENT_TYPE 设置的值。默认为'text/html'
  9.  
  10. status:响应的状态码。默认为200
  11.  
  12.    useing: 用于加载模板的模板引擎的名称。
  13.  
  14. 一个简单的例子:
  1. from django.shortcuts import render
  2.  
  3. def my_view(request):
  4. # 视图的代码写在这里
  5. return render(request, 'myapp/index.html', {'foo': 'bar'})

上面的代码等于:

  1. from django.http import HttpResponse
  2. from django.template import loader
  3.  
  4. def my_view(request):
  5. # 视图代码写在这里
  6. t = loader.get_template('myapp/index.html')
  7. c = {'foo': 'bar'}
  8. return HttpResponse(t.render(c, request))

redirect()

参数可以是:

  • 一个模型:将调用模型的get_absolute_url() 函数
  • 一个视图,可以带有参数:将使用urlresolvers.reverse 来反向解析名称
  • 一个绝对的或相对的URL,将原封不动的作为重定向的位置。

默认返回一个临时的重定向;传递permanent=True 可以返回一个永久的重定向。

示例:

你可以用多种方式使用redirect() 函数。

传递一个具体的ORM对象(了解即可)

将调用具体ORM对象的get_absolute_url() 方法来获取重定向的URL:

  1. from django.shortcuts import redirect
  2.  
  3. def my_view(request):
  4. ...
  5. object = MyModel.objects.get(...)
  6. return redirect(object)

传递一个视图的名称

  1. def my_view(request):
  2. ...
  3. return redirect('some-view-name', foo='bar')

传递要重定向到的一个具体的网址

  1. def my_view(request):
  2. ...
  3. return redirect('/some/url/')

当然也可以是一个完整的网址

  1. def my_view(request):
  2. ...
  3. return redirect('http://example.com/')

默认情况下,redirect() 返回一个临时重定向。以上所有的形式都接收一个permanent 参数;如果设置为True,将返回一个永久的重定向:

  1. def my_view(request):
  2. ...
  3. object = MyModel.objects.get(...)
  4. return redirect(object, permanent=True) 

扩展阅读:

临时重定向(响应状态码:302)和永久重定向(响应状态码:301)对普通用户来说是没什么区别的,它主要面向的是搜索引擎的机器人。

A页面临时重定向到B页面,那搜索引擎收录的就是A页面。

A页面永久重定向到B页面,那搜索引擎收录的就是B页面。

补充(文件上传):

路由:

  1. urlpatterns = [
  2. url(r'^upload/$',views.Upload.as_view()),
  3. ]

urls.py

视图:

  1. # Django上传文件示例
  2. class Upload(views.View):
  3. def get(self, request):
  4. return render(request, "upload.html")
  5.  
  6. def post(self, request):
  7. # 拿到用户发送的文件数据
  8. file_obj = request.FILES.get("code")
  9. # 保存下来
  10. # 1. 拿到用户上传的文件名
  11. filename = file_obj.name
  12. # 2. 在服务端创建一个同名的文件
  13. with open(filename, "wb") as f:
  14. # 3. 从用户上传的文件对象中一点一点读数据,往我本地创建的文件句柄里一点一点写
  15. for i in file_obj.chunks():#可指定数据量
  16. f.write(i)
  17. return HttpResponse("上传成功!")

views.py

模板:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>上传文件</title>
  6. </head>
  7. <body>
  8.  
  9. <form action="/upload/" method="post" enctype="multipart/form-data">
  10. <input type="file" name="code">
  11. <input type="submit" value="提交">
  12. </form>
  13. </body>
  14. </html>

upload.html

注意:

前端页面
1. form表单一定要有action,method必须是post
2. 一定要配置enctype="multipart/form-data"

此处默认会上传到app01下面。

Django框架简介-视图系统的更多相关文章

  1. Django框架简介-路由系统

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

  2. django框架基础-视图系统-长期维护

    ##################   什么是视图?     ####################### 视图: 1,一个视图函数(类),简称视图,是一个简单的Python 函数(类),它接受W ...

  3. Django框架简介-模型系统

    2.5 模型 2.5.1 ORM介绍 2.5.1.1 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现 ...

  4. Django框架简介-模板系统

    2.4 模板 官方文档 2.4.1 常用语法 只需要记两种特殊符号: {{  }}和 {% %} 变量相关的用{{}},逻辑相关的用{%%}. 2.4.1.1 变量 {{ 变量名 }} 变量名由字母数 ...

  5. python 之 Django框架(Django框架简介、视图装饰器、request对象、Response对象)

    12.33 Django框架简介: MVC,全名是Model View Controller,是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View)和控制器( ...

  6. Python学习(三十)—— Django框架简介

    转载自:http://www.cnblogs.com/liwenzhou/p/8296964.html Django框架简介 一.MVC框架和MTV框架(了解即可) MVC,全名是Model View ...

  7. Django框架简介及模板Template,filter

    Django框架简介 MVC框架和MTV框架 MVC,全名是Model View Controller,是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View) ...

  8. Django框架简介与使用注意事项

    一.Django框架简介 MVC框架和MTV框架 MVC框架 MVC,全名是Model View Controller,是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model). ...

  9. wsgiref模块、web框架、django框架简介

    """web框架:将前端.数据库整合到一起的基于互联网传输的python代码 web框架也可以简单的理解为是软件开发架构里面的'服务端'""" ...

随机推荐

  1. Postman 进阶(pre-request scripts&test script)

    Postman 进阶 1. pre-request scripts   pre-request scripts是一个关联了收藏夹内request,并且在发送request之前执行的代码片段.这对于在r ...

  2. docker单机网络类型

    docker单机网络类型概述 Docker 安装时会自动在 host 上创建三种网络  分别为 bridge    host   none .   可用 docker network ls 命令查看 ...

  3. python框架之Django(10)-Form组件

    介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来.与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否输入,输入 ...

  4. 引入css的两种方式

    摘自:https://www.cnblogs.com/gyjWEB/p/4831646.html 在HTML中引入css的其中的两个方法: 1.如果使用链接式,需要使用如下的语句引入外部css文件: ...

  5. PHP中new self()和new static()的区别探究

    1.new static()是在PHP5.3版本中引入的新特性. 2.无论是new static()还是new self(),都是new了一个新的对象. 3.这两个方法new出来的对象有什么区别呢,说 ...

  6. openshift 容器云从入门到崩溃之四《配置用户验证》

    1.配置本地用户 之前安装的时候选择了htpasswd验证方式 先创建用户 # htpasswd -c /etc/origin/master/htpasswd admin 授权为集群管理员 # oc ...

  7. Linux更新时,出现无法更新锁

    1.查看软件中心是否有更新 2.重启 3.rm/var/lib/dpkg/lock 4.sudo apt-get update 5.sudo dpkg --configure -a

  8. AR(I)MA时间序列建模过程——步骤和python代码

    https://www.jianshu.com/p/cced6617b423 https://zhuanlan.zhihu.com/p/35282988 https://zhuanlan.zhihu. ...

  9. 单源最短路——Dijkstara算法

    算法基本思想:每次找到离源点最近的一个顶点,然后以该顶点为中心进行扩展,最终得到源点到其余所有点的最短路径. 1.将所有的顶点分为两个部分:已知最短路程的顶点集合P和未知最短路径的顶点集合Q 2.设置 ...

  10. jQuery图片无缝轮播

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...