HttpResponse对象

阅读: 32804

评论:3

HttpResponse类定义在django.http模块中。

HttpRequest对象是浏览器发送过来的请求数据的封装,HttpResponse对象则是你想要返回给浏览器的数据的封装。

HttpRequest对象由Django自动解析HTTP数据包而创建,而HttpResponse对象则由程序员手动创建。

我们编写的每个视图都要实例化、填充和返回一个HttpResponse对象。也就是函数的return值。

一、使用方法

1. 返回一个字符串

最简单的方式是传递一个string、bytes或者memoryview(Python3.8新增的一种类型)作为页面的内容到HttpResponse构造函数,并返回给用户:

>>> from django.http import HttpResponse

>>> response = HttpResponse("Here's the text of the Web page.")

>>> response = HttpResponse("Text only, please.", content_type="text/plain")

>>> response = HttpResponse(b'Bytestrings are also accepted.')

>>> response = HttpResponse(memoryview(b'Memoryview as well.'))

可以将response看做一个类文件对象,使用wirte()方法不断地往里面增加内容。

>>> response = HttpResponse()

>>> response.write("

Here's the text of the Web page.

")

>>> response.write("

Here's another paragraph.

")

2. 传递可迭代对象

你甚至可以传递一个可迭代的对象给HttpResponse。比如 StreamingHttpResponse 。

HttpResponse会立即处理这个迭代器,并把它的内容存成字符串,最后废弃这个迭代器。比如文件在读取后,会立刻调用close()方法,关闭文件。

3. 设置头部字段

可以把HttpResponse对象当作一个字典一样,在其中增加和删除头部字段。

>>> response = HttpResponse()

>>> response['Age'] = 120

>>> del response['Age']

注意!与字典不同的是,如果要删除的头部字段如果不存在,del不会抛出KeyError异常。

HTTP的头部字段中不能包含换行。所以如果我们提供的头部字段值包含换行符(CR或者LF),将会抛出BadHeaderError异常。

4. 附件形式

让浏览器以文件附件的形式处理响应, 需要声明content_type类型和设置Content-Disposition头信息。 例如,给浏览器返回一个微软电子表格:

>>> response = HttpResponse(my_data, content_type='application/vnd.ms-excel')

>>> response['Content-Disposition'] = 'attachment; filename="foo.xls"'

二、属性

content

响应的内容。bytes类型。

charset

编码的字符集。 如果没指定,将会从content_type中解析出来。

status_code

响应的状态码,比如200。

reason_phrase

响应的HTTP原因短语。 使用标准原因短语。

除非明确设置,否则reason_phrase由status_code的值决定。

streaming

这个属性的值总是False。由于这个属性的存在,使得中间件能够区别对待流式响应和常规响应。

closed

如果响应已关闭,那么这个属性的值为True。

三、 方法

__init__()

__init__(content=b'', content_type=None, status=200, reason=None, charset=None)

响应的实例化方法。使用content参数和content-type实例化一个HttpResponse对象。

content应该是一个迭代器或者字符串。如果是迭代器,这个迭代期返回的应是一串字符串,并且这些字符串连接起来形成response的内容。 如果不是迭代器或者字符串,那么在其被接收的时候将转换成字符串。

content_type是可选地,用于填充HTTP的Content-Type头部。如果未指定,默认情况下由DEFAULT_CONTENT_TYPE和DEFAULT_CHARSET设置组成:text/html; charset=utf-8。

status是响应的状态码。reason是HTTP响应短语。charset是编码方式。

__setitem__(header, value)

设置头部的键值对。两个参数都必须为字符串类型。

__delitem__(header)

删除头部的某个键。键不存在的话,不会报错。不区分大小写。

__getitem__(header)

返回对应键的值。不区分大小写。

has_header(header)

检查头部中是否有给定的名称(不区分大小写),返回True或 False。

setdefault(header, value)

设置一个头部,除非该头部已经设置过了。

set_cookie()

set_cookie(key, value='', max_age=None, expires=None, path='/', domain=None, secure=False, httponly=False, samesite=None)

这个方法你必须会。

设置一个Cookie。 参数与Python标准库中的Morsel.Cookie对象相同。

max_age: 生存周期,以秒为单位。如果设为None,浏览器开启期间保持,关闭后一同删除。

expires:到期时间。

domain: 用于设置跨域的Cookie。例如domain=".lawrence.com"将设置一个www.lawrence.com、blogs.lawrence.com和calendars.lawrence.com都可读的Cookie。 否则,Cookie将只能被设置它的域读取。

secure=True:支持https

httponly=True:阻止客户端的js代码访问cookie

使用samesite='Strict'或samesite='Lax'告诉浏览器在执行跨源请求时不要发送此cookie。并非所有浏览器都支持SameSite,因此它不是Django的CSRF保护的替代品,而是一种深度防御措施。

使用samesite='None'(string)显式声明此cookie与所有相同站点和跨站点请求一起发送。

set_signed_cookie()

set_signed_cookie(key, value, salt='', max_age=None, expires=None, path='/', domain=None, secure=False, httponly=False, samesite=None)

与set_cookie()类似,但是在设置之前将对cookie进行加密签名。通常与HttpRequest.get_signed_cookie()一起使用。

delete_cookie()

delete_cookie(key, path='/', domain=None, samesite=None)

删除Cookie中指定的key。

由于Cookie的工作方式,path和domain应该与set_cookie()中使用的值相同,否则Cookie不会删掉。

close()

在请求结束后WSGI服务器会调用此方法,关闭连接

write(content)

将HttpResponse实例看作类似文件的对象,往里面添加内容。

flush()

清空HttpResponse实例的内容。

tell()

将HttpResponse实例看作类似文件的对象,移动位置指针。

getvalue()

返回HttpResponse.content的值。 此方法将HttpResponse实例看作是一个类似流的对象。

readable()

返回的值始终为False。判断是否可读

seekable()

值始终为False。判断指针是否可以移动。

writable()

值始终为True。判断是否可写。

writelines(lines)

将一个包含行的列表写入响应对象中。 不添加分行符。

四、HttpResponse的子类

Django包含了一系列的HttpResponse的衍生类(子类),用来处理不同类型的HTTP响应。与HttpResponse相同, 这些衍生类存在于django.http之中。这些子类并不算复杂,代码也很简单,主要就是响应码的不同。

class HttpResponseRedirect:重定向,返回302状态码。已经被redirect()替代。

class HttpResponsePermanentRedirect:永久重定向,返回301状态码。

class HttpResponseNotModified:未修改的页面,返回304状态码。

class HttpResponseBadRequest:错误的请求,返回400状态码。

class HttpResponseNotFound:页面不存在,返回404状态码。

class HttpResponseForbidden:禁止访问,返回403状态码。

class HttpResponseNotAllowed:禁止访问,返回405状态码。

class HttpResponseGone:过期,返回405状态码。

class HttpResponseServerError:服务器错误,返回500状态码。

其实,你还可以自定义HttpResponse的子类,如下所示:

from http import HTTPStatus

from django.http import HttpResponse

class HttpResponseNoContent(HttpResponse):

status_code = HTTPStatus.NO_CONTENT

五、JsonResponse类

class JsonResponse(data, encoder=DjangoJSONEncoder, safe=True, json_dumps_params=None, **kwargs)

JsonResponse是HttpResponse的一个子类,是Django提供的用于创建JSON编码类型响应的快捷类。

它从父类继承大部分行为,并具有以下不同点:

它的Content-Type头部为application/json

它的第一个参数data,应该为一个字典数据类型。

只有将safe参数设置为False,才可以将任何可JSON 序列化的对象作为data的参数值,否则会报错。

encoder默认为django.core.serializers.json.DjangoJSONEncoder,用于序列化数据。

典型的用法如下:

>>> from django.http import JsonResponse

>>> response = JsonResponse({'foo': 'bar'})

>>> response.content

b'{"foo": "bar"}'

若要序列化非dict对象,必须设置safe参数为False:

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

如果不传递safe=False,将抛出一个TypeError。

如果你需要使用不同的JSON 编码器类,可以传递encoder参数给构造函数:

>>> response = JsonResponse(data, encoder=MyJSONEncoder)

六、StreamingHttpResponse类

StreamingHttpResponse类被用来从Django响应一个流式对象到浏览器。如果生成的响应太长或者是占用的内存较大,这么做更有效率。 例如,生成大型的CSV文件。

StreamingHttpResponse不是HttpResponse的子类(而是兄弟类),但是除了几个明显不同的地方,两者几乎完全相同:

StreamingHttpResponse接收一个迭代器作为参数。这个迭代器返回bytes类型的字符内容。

StreamingHttpResponse的内容是一个整体的对象,不能直接访问修改

StreamingHttpResponse有一个 streaming_content属性

你不能在StreamingHttpResponse上使用类似文件操作的tell和write方法

由于StreamingHttpResponse的内容无法访问,因此许多中间件无法正常工作。例如,不能为流式响应生成ETag和Content-Length头。

StreamingHttpResponse对象有下面的属性

streaming_content:一个包含响应内容的迭代器,通过HttpResponse.charset编码为bytes类型。

status_code:响应的状态码

reason_phrase:响应的原语

streaming:总是为True

七、FileResponse

class FileResponse(open_file, as_attachment=False, filename='', **kwargs)

文件类型响应。通常用于给浏览器返回一个文件附件。

FileResponse是StreamingHttpResponse的子类,为二进制文件专门做了优化。

FileResponse需要通过二进制模式打开文件,如下:

>>> from django.http import FileResponse

>>> response = FileResponse(open('myfile.png', 'rb'))

文件会被自动关闭,所以不需要在上下文管理器中打开。

如果 as_attachment=True,则Content-Disposition 被设置为 attachment,,告诉浏览器这是一个附件,以文件形式下载。否则 Content-Disposition 会被设置为 inline (浏览器默认行为)。

如果open_file参数传递的类文件对象没有名字,或者名字不合适,那么你可以通过filename参数为文件对象指定一个合适的名字。

评论总数: 3

完成

By

多浪的河流   On

2020年11月5日 20:44

回复

HttpResponse≈文件对象+字典对象

By

蔷薇-Nina   On

2019年7月9日 21:48

回复

每天学习一点点

By

王希知   On

2019年3月14日 21:01

回复

python中response对象的方法_django HttpResponse对象 - 刘江的django教程相关推荐

  1. python中response对象的属性_关于python:AttributeError:’HTTPResponse’对象没有属性’split’...

    我正在尝试从Google财经获取一些信息,但出现此错误 AttributeError: 'HTTPResponse' object has no attribute 'split' 这是我的pytho ...

  2. python中实例方法分类_python方法的分类(实例方法、类方法、静态方法)

    方法和函数的区分 很多童鞋会比较疑惑,方法和函数有什么区别,都是通过def去定义的啊? 只需要记住一点,方法是用来描述一个目标的行为动作! 不论你是直接通过 类名.方法调用,还是通过由类生成的实例.方 ...

  3. python中立方表示_在Python中表示一个对象的方法

    在 Python 中一切都是对象.如果要在 Python 中表示一个对象,除了定义 class 外还有哪些方式呢?我们今天就来盘点一下. 0x00 dict 字典或映射存储 KV 键值对,它对查找.插 ...

  4. python中使用grpc方法示例_在Python中使用gRPC的方法示例

    本文介绍了在Python中使用gRPC的方法示例,分享给大家,具体如下: 使用Protocol Buffers的跨平台RPC系统. 安装 使用 pip pip install grpcio pip i ...

  5. python中各种属性与方法深析

    在了解类的继承之后,我们需要特别知道以下几个概念及其具体使用: (1)私有属性: (2)私有方法: (3)类属性: (4)类方法: (5)静态方法: 注意:python在类中没有声明的话,所有的方法都 ...

  6. python 中的 __len__(self) 方法

    __len__方法 1. 注意:__len__ 方法一般与 len(对象) 方法搭配使用.即先在__len__方法中说明需要求类中的哪个属性(假如是属性a)的长度,当使用 len(对象A) 方法时会得 ...

  7. 计算机语言range,python中range输出的方法

    python中range输出的方法 发布时间:2020-08-25 11:50:26 来源:亿速云 阅读:148 作者:小新 这篇文章主要介绍python中range输出的方法,文中介绍的非常详细,具 ...

  8. python 土拨鼠库_傻傻分不清楚系列|Python中各种时间处理方法(上)

    相信大多数数据分析师在入手Python的时候,在学习到time库与datetime库时,都会对两个库里面长得很像,又相互有关联的各种类和方法感到非常窝心.当接触到pandas处理时间序列的方法时,再次 ...

  9. chatgpt赋能python:Python中的s.len()方法介绍

    Python中的s.len()方法介绍 Python中有各种字符串处理方法,其中s.len()方法是一个重要的方法之一.s.len()返回一个字符串s的长度.这是一个非常基本的方法,但是在很多情况下都 ...

最新文章

  1. R语言使用pwr包的pwr.f2.test函数对线性回归模型进行效用分析(power analysis)、在已知效应量(effect size)、显著性水平、效用值的情况下计算需要的样本量
  2. 人人都能成为安全防范的高手 ——《黑客新型攻击防范:深入剖析犯罪软件》
  3. python字符串、列表和文件对象总结
  4. python与excel结合-Python和Excel终于可以
  5. java开心农场安卓_开心农场之田园日记
  6. mPaas 研发流程和线上运维介绍
  7. LVM逻辑卷,RAID磁盘阵列
  8. TextArea里Placeholder换行问题
  9. qoq是什么意思的缩写_买鞋多年分不清PE、SE、TD什么意思?建议收藏,这些缩写一定要知道...
  10. Eclipse基础--java环境变量设置
  11. Proteus 8.12 仿真软件安装(Proteus8.6Proteus8.14下载)
  12. 题解 伊甸园日历游戏
  13. 浪潮之巅--摩托罗拉
  14. 【数字IC/FPGA】时钟无毛刺切换
  15. js绘制菱形(空心和实心)
  16. 像这2个案例的项目进度延误,如何破?
  17. excel表格怎么输入001
  18. Python绘制MACD指标图
  19. 夏至日环食奇趣天象将在中国天空上演 错过再等十年
  20. 车易加加油优惠卡_丰田Supra GRMN或2023年发布可 能搭载宝马3.0T发动机

热门文章

  1. el-talbe如何在打印的时候,每页都能有表头?
  2. 微信小程序修改制作生成头像——校庆头像制作小程序
  3. 不知道虚拟化?看这篇就够了!
  4. get_sequencer的用法总结
  5. 【Linux】Ubuntu16.04使用拾遗2
  6. 多功能纺织品易燃性测试仪市场现状及未来发展趋势
  7. “苹果”在中国的血汗工厂
  8. CITAHub 社区成员开源 CITA SDK Python 组件
  9. 如何选择回归损失函数
  10. python中用来抛出异常的关键字是( )_python如何抛出异常