Django 2.1.7 视图 - HttpResponse对象、子类JsonResponse、子类HttpResponseRedirect

本文主要是介绍Django 2.1.7 视图 - HttpResponse对象、子类JsonResponse、子类HttpResponseRedirect,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

13423234-c8e484b60d8cd3cc.png

关于视图的篇章

Django 2.1.7 视图
Django 2.1.7 MVT模型示例 - 查询数据,返回渲染模板数据
Django 2.1.7 视图 - 自定义404错误、500错误
Django 2.1.7 视图 - HttpReqeust对象、QueryDict对象

HttpResponse对象

视图在接收请求并处理后,必须返回HttpResponse对象或子对象。在django.http模块中定义了HttpResponse对象的API。HttpRequest对象由Django创建,HttpResponse对象由开发人员创建。

运行服务器,在浏览器中浏览首页,可以在浏览器“开发者工具”中看到响应信息如下图:

标号3为响应头信息,点击标号4处可以查看响应体信息。

13423234-4417772bacba6388.png

属性

  • content:表示返回的内容。
  • charset:表示response采用的编码字符集,默认为utf-8。
  • status_code:返回的HTTP响应状态码。
  • content-type:指定返回数据的的MIME类型,默认为'text/html'。

方法

  • _init_:创建HttpResponse对象后完成返回内容的初始化。
  • set_cookie:设置Cookie信息。
    set_cookie(key, value='', max_age=None, expires=None)
  • cookie是网站以键值对格式存储在浏览器中的一段纯文本信息,用于实现用户跟踪。
    • max_age是一个整数,表示在指定秒数后过期。
    • expires是一个datetime或timedelta对象,会话将在这个指定的日期/时间过期。
    • max_age与expires二选一。
    • 如果不指定过期时间,在关闭浏览器时cookie会过期。
  • delete_cookie(key):删除指定的key的Cookie,如果key不存在则什么也不发生。
    write:向响应体中写数据。

示例

直接返回数据

1)打开assetinfo/views.py文件,定义视图index2如下:

def index2(request):str = '<h1>hello world</h1>'return HttpResponse(str)

2)打开assetinfo/urls.py文件,配置url。

urlpatterns = [# ex:/assetinfo/index2path('index2', views.index2),....
]

3)运行服务器,在浏览器中打开如下网址。

http://127.0.0.1:8000/assetinfo/index2
13423234-a5c6bd767fb5e4ea.png

如果使用这种方式构造一个漂亮丰富的页面,对于开发人员真是会发疯,于是就有了下面的方式:

调用模板

可以将html、css、js定义到一个html文件中,然后由视图来调用。

1)打开assetinfo/views.py文件,定义视图index3如下:

from django.template import loaderdef index3(request):# 1.获取模板template = loader.get_template('assetinfo/index3.html')# 2.定义上下文context = {'h1': 'Hello world',}# 3.渲染模板return HttpResponse(template.render(context, request))

2)打开assetinfo/urls.py文件,配置url。

urlpatterns = [# ex:/assetinfo/index3path('index3', views.index3),...
]

3)在templates/assetinfo/目录下创建index3.html,代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body><h1>{{h1}}</h1>
</body>
</html>

4)运行服务器,在浏览器中打开如下网址。

http://127.0.0.1:8000/assetinfo/index3
13423234-96a506d8314911c1.png

调用模板简写函数render

每次调用模板时都要执行加载、上下文、渲染三个步骤,为了简化操作,Django定义了render()函数封装了以上三个步骤的代码,定义在django.shortcuts模块中。

1)打开assetinfo/views.py文件,定义视图index3如下:

from django.shortcuts import renderdef index3(request):context = {'h1': 'Hello world',}return render(request, 'assetinfo/index3.html', context=context)

子类JsonResponse

在浏览器中使用javascript发起ajax请求时,返回json格式的数据,此处以jquery的get()方法为例。类JsonResponse继承自HttpResponse对象,被定义在django.http模块中,创建对象时接收字典作为参数。

JsonResponse对象的content-type为'application/json'。

示例

1)在assetinfo/views.py文件中定义视图json1、json2,代码如下:

from django.http import JsonResponsedef json1(request):return render(request,'assetinfo/json1.html')def json2(request):return JsonResponse({'h1':'hello','h2':'world'})

2)在assetinfo/urls.py文件中配置url。

urlpatterns = [# ex:/assetinfo/json1path('json1', views.json1),# ex:/assetinfo/json2path('json2', views.json2),....
]

3)在templates/assetinfo/目录下创建json1.html,代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><script src="/static/js/jquery-3.0.0.min.js"></script><script>$(function () {$('#btnJson').click(function () {$.get('/assetinfo/json2',function (data) {ul=$('#jsonList');ul.append('<li>'+data['h1']+'</li>')ul.append('<li>'+data['h2']+'</li>')})});});</script>
</head>
<body><input type="button" id="btnJson" value="获取json数据"><ul id="jsonList"></ul>
</body>
</html>

4)运行服务器,在浏览器中输入如下地址。

13423234-77dc4a58518670cd.png
13423234-2b2f55be074762dc.png

好了,到这里就可以点击json1页面中的按钮,通过ajax获取json2的json返回数据了。
如下:

13423234-040180b1c91c4c7a.png

ajax代码执行过程如下:

1.发起请求。
2.服务器端视图函数执行。
3.执行回调函数。

子类HttpResponseRedirect

当一个逻辑处理完成后,不需要向客户端呈现数据,而是转回到其它页面,如添加成功、修改成功、删除成功后显示数据列表,而数据的列表视图已经开发完成,此时不需要重新编写列表的代码,而是转到这个视图就可以,此时就需要模拟一个用户请求的效果,从一个视图转到另外一个视图,就称为重定向。

Django中提供了HttpResponseRedirect对象实现重定向功能,这个类继承自HttpResponse,被定义在django.http模块中,返回的状态码为302。

示例

1)在assetinfo/views.py文件中定义视图red1,代码如下:

from django.http import HttpResponseRedirect# 定义重定义向视图,转向刚刚创建的json1页面
def red1(request):return HttpResponseRedirect('json1')

2)在asserinfo/urls.py文件中配置url。

urlpatterns = [# ex:/assetinfo/red1path('red1', views.red1),....
]

3)访问浏览器测试重定向
访问 http://127.0.0.1:8000/assetinfo/red1

13423234-959a0ca21242c88b.png

可以看到页面重定向到访问json1的页面了。

4)查看django的日志信息

[17/Jun/2019 20:37:20] "GET /assetinfo/red1 HTTP/1.1" 302 0
[17/Jun/2019 20:37:20] "GET /assetinfo/json1 HTTP/1.1" 200 629

可以收到/assetinfo/red1的路径请求,然后302转发到另一个路径去。

重定向简写函数redirect

在django.shortcuts模块中为重定向类提供了简写函数redirect。

1)修改assetinfo/views.py文件中red1视图,代码如下:

from django.shortcuts import redirect# 定义重定义向视图,转向刚刚创建的json1页面
def red1(request):return redirect('/assetinfo/json1')

其实就是封装了一下HttpResponseRedirect对象而已。但是路径转发要加上全路径了,这个要注意一下。

13423234-0e3934319aa622f6.png

这篇关于Django 2.1.7 视图 - HttpResponse对象、子类JsonResponse、子类HttpResponseRedirect的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1092097

相关文章

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

数据视图(AngularJS)

<!DOCTYPE html><html ng-app="home.controller"><head><meta charset="utf-8"><title>数据视图</title><link href="page/common/css/bootstrap.min.css" rel="stylesheet"><script src="page/common/js/angular.js"></

Java第二阶段---09类和对象---第三节 构造方法

第三节 构造方法 1.概念 构造方法是一种特殊的方法,主要用于创建对象以及完成对象的属性初始化操作。构造方法不能被对象调用。 2.语法 //[]中内容可有可无 访问修饰符 类名([参数列表]){ } 3.示例 public class Car {     //车特征(属性)     public String name;//车名   可以直接拿来用 说明它有初始值     pu

利用Django框架快速构建Web应用:从零到上线

随着互联网的发展,Web应用的需求日益增长,而Django作为一个高级的Python Web框架,以其强大的功能和灵活的架构,成为了众多开发者的选择。本文将指导你如何从零开始使用Django框架构建一个简单的Web应用,并将其部署到线上,让世界看到你的作品。 Django简介 Django是由Adrian Holovaty和Simon Willison于2005年开发的一个开源框架,旨在简

HTML5自定义属性对象Dataset

原文转自HTML5自定义属性对象Dataset简介 一、html5 自定义属性介绍 之前翻译的“你必须知道的28个HTML5特征、窍门和技术”一文中对于HTML5中自定义合法属性data-已经做过些介绍,就是在HTML5中我们可以使用data-前缀设置我们需要的自定义属性,来进行一些数据的存放,例如我们要在一个文字按钮上存放相对应的id: <a href="javascript:" d

【2.1 深度学习中的感知机是什么】

2.1 深度学习中的感知机是什么 深度学习是机器学习的一个分支,它模拟人脑的工作方式来处理数据,尤其是通过神经网络的结构来自动提取数据的特征并进行分类、回归或其他复杂的任务。在深度学习的早期发展中,许多基础概念和模型为后续的复杂网络奠定了基础。其中,**感知机(Perceptron)**是一个非常重要的基础模型,它实际上是神经网络和深度学习的前身之一。 感知机的基本概念 感知机是一种二分

PHP7扩展开发之对象方式使用lib库

前言 上一篇文章,我们使用的是函数方式调用lib库。这篇文章我们将使用对象的方式调用lib库。调用代码如下: <?php $hello = new hello(); $result = $hello->get(); var_dump($result); ?> 我们将在扩展中实现hello类。hello类中将依赖lib库。 代码 基础代码 这个扩展,我们将在say扩展上增加相关代码。sa

hibernate修改数据库已有的对象【简化操作】

陈科肇 直接上代码: /*** 更新新的数据并并未修改旧的数据* @param oldEntity 数据库存在的实体* @param newEntity 更改后的实体* @throws IllegalAccessException * @throws IllegalArgumentException */public void updateNew(T oldEntity,T newEntity

类和对象的定义和调用演示(C++)

我习惯把类的定义放在头文件中 Student.h #define _CRT_SECURE_NO_WARNINGS#include <string>using namespace std;class student{public:char m_name[25];int m_age;int m_score;char* get_name(){return m_name;}int set_name

react笔记 8-19 事件对象、获取dom元素、双向绑定

1、事件对象event 通过事件的event对象获取它的dom元素 run=(event)=>{event.target.style="background:yellowgreen" //event的父级为他本身event.target.getAttribute("aid") //这样便获取到了它的自定义属性aid}render() {return (<div><h2>{