Django中Request和Response

1,HttpRequest知识总结

定义:

服务器接收到http协议的请求后,会根据报文创建HttpRequest对象,这个对象不需要我们创建,直接使用服务器构造好的对象就可以。视图的第一个参数必须是HttpRequest对象,在django.http模块中定义了HttpRequest对象的API。

属性:

path:一个字符串,表示请求的页面的完整路径,不包含域名。

method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET'、'POST'。
在浏览器中给出地址发出请求采用get方式,如超链接。
在浏览器中点击表单的提交按钮发起请求,如果表单的method设置为post则为post请求。

encoding:一个字符串,表示提交的数据的编码方式。
如果为None则表示使用浏览器的默认设置,一般为utf-8。
这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码

GET:一个类似于字典的对象,包含get请求方式的所有参数。

POST:一个类似于字典的对象,包含post请求方式的所有参数。

FILES:一个类似于字典的对象,包含所有的上传文件。

COOKIES:一个标准的Python字典,包含所有的cookie,键和值都为字符串。

session:一个既可读又可写的类似于字典的对象,表示当前的会话,只有当Django 启用会话支持时才可用
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

QueryDict对象

  • 定义在django.http.QueryDict
  • HttpRequest对象的属性GET、POST都是QueryDict类型的对象
  • 与python字典不同,QueryDict类型的对象用来处理同一个键带有多个值的情况

方法get():根据键获取值 
如果一个键同时拥有多个值将获取最后一个值 
如果键不存在则返回None值,可以设置默认值进行后续处理

dict.get('键',默认值)
可简写为
dict['键']
  • 1
  • 2
  • 3

方法getlist():根据键获取值,值以列表返回,可以获取指定键的所有值 
如果键不存在则返回空列表[],可以设置默认值进行后续处理

dict.getlist('键',默认值)
  • 1

GET属性

  • 请求格式:
  • 在请求地址结尾使用?,之后以“键=值”的格式拼接,多个键值对之间以&连接。

例:网址如下

http://www.baidu.com/?name=xiaoke&age=26&hobby=python

其中的请求参数为:

name=xiaoke&age=26&hobby=python

分析请求参数:

键为’name’、’age’、’hobby’,值为’xiaoke’、’26’、’python’。 
在Django中可以使用HttpRequest对象的GET属性获得get方方式请求的参数。 
GET属性返回QueryDict类型的对象,键和值都是字符串类型。 
键是开发人员在编写代码时确定下来的。 
值是根据数据生成的。

POST属性

  • 使用form表单请求时,method方式为post则会发起post方式的请求,需要使用HttpRequest对象的POST属性接收参数,POST属性返回QueryDict类型的对象。

问:表单form如何提交参数呢? 
答:控件name属性的值作为键,value属性的值为值,构成键值对提交。 
如果控件没有name属性则不提交。 
对于checkbox控件,name属性的值相同为一组,被选中的项会被提交,出现一键多值的情况。 
键是控件name属性的值,是由开发人员编写的。 
值是用户填写或选择的。

2,HttpResponse对象

定义

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

属性

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

方法

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

    set_cookie(key, value=”, max_age=None, expires=None)

  • delete_cookie(key):删除指定的key的Cookie,如果key不存在则什么也不发生。

子类JsonResponse

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

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

子类HttpResponseRedirect

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

  • Django中提供了HttpResponseRedirect对象实现重定向功能,这个类继承自HttpResponse,被定义在django.http模块中,返回的状态码为302
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值