Django Request 与Response对象

  Django使用请求和响应对象在系统中传递状态。当请求页面时,Django创建一个HttpRequest对象,该对象包含关于请求的元数据。

然后Django加载适当的视图,将HttpRequest作为第一个参数传递给视图函数。每个视图都负责返回HttpResponse对象。


 

一、HttpRequest

HttpRequet.schema:所使用的Http协议(http,https)

HttpRequest.body:请求体

HttpRequest.path:表示请求页面的完整路径的字符串,不包括模式或域Http。

HttpRequest.path_info:与path相比只包含路径信息

HttpRequest.method:请求方法

HttpRequest.encoding:表示用于解码表单提交数据的当前编码(或无编码

HttpRequest.content_type:表示请求MIME类型的字符串,从CONTENT_TYPE报头解析。

HttpRequest.content_params:一个包含在CONTENT_TYPE头中的键/值参数的字典。

HttpRequest.COOKIES:包含所有cookie的字典。键和值是字符串。

HttpRequest.FILES:一个类字典的对象,包含所有上传的文件。文件中的每个键都是 上传文件的表单的名称。文件中的每个值都是UploadedFile。只有当请求方法是POST且发送到请求的具有enctype="multipart/form-data"时,文件才会包含数据。否则,文件将是一个空白的类字典对象。

HttpRequest.session:表示当前会话的可读和可写的、类似词典的对象。

HttpRequest.ste:当前站点

HttpRequest.user:表示当前登录的用户。如果用户当前没有登录,用户将被设置为AnonymousUser实例。

HttpRequest.get_full_path:获取当前URL路径

HttpRequest.get_signed_cookie():返回已签名cookie的cookie值,或引发django.core.sign。如果签名不再有效,则出现BadSignature异常。如果您提供默认参数,异常将被抑制,而该默认值将被返回。

HttpRequest.is_ajax():判断是否是Ajax请求


 

二、QueryDict对象

大部分字典方法都适用

QueryDict.__init__(query_string=None,mutable=False,encoding=None)

>>> QueryDict('a=1&a=2&c=3')
<QueryDict: {'a': ['1', '2'], 'c': ['3']}>

QueryDict.fromkeys()

>>> QueryDict.fromkeys(['a', 'a', 'b'], value='val')
<QueryDict: {'a': ['val', 'val'], 'b': ['val']}>

QueryDict.__geyitem__(key):返回key的值

QueryDict.__contains__(key):允许in运算

QueryDict.lists():与items()类似,只不过它以列表的形式包含字典中每个成员的所有值。

>>> q = QueryDict('a=1&a=2&a=3')
>>> q.lists()
[('a', ['1', '2', '3'])]

 

QueryDict.urlencode():

>>> q = QueryDict('a=2&b=3&b=5')
>>> q.urlencode()
'a=2&b=3&b=5'

 


 

三、HttpResponse对象

向HttpResponse中传递迭代器,将会立即遍历迭代器,转换成字符串后丢弃。如果需要将响应从迭代器流到客户机,则必须使用StreamingHttpResponse类。

添加键值对

>>> response = HttpResponse()
>>> response['Age'] = 120
>>> del response['Age']

HttpResponse.__init__(content='', content_type=None, status=200, reason=None, charset=None):初始化一个response

HttpResponse.set_cookie(key, value='', max_age=None, expires=None, path='/', domain=None, secure=None, httponly=False, samesite=None):设置cookie

max_age应该是秒数,或者None,如果cookie仅持续客户端的浏览器会话时间,则为0秒(默认)。如果未指定过期,将计算过期时间。

expires可以是“Wdy, DD-Mon-YY HH:MM:SS GMT”格式的字符串,也可以是datetime格式。UTC中的datetime对象。如果expires是datetime对象,则计算max_age。

如果您想设置跨域cookie,请使用domain。例如,domain="example.com"将设置一个cookie,该cookie可以被www.example.com、blog.example.com等域读取。否则,cookie只能被设置cookie的域读取

如果希望阻止客户端JavaScript访问cookie,请使用httponly=True。

HTTPOnly是一个包含在Set-Cookie HTTP响应头中的标志。它不是RFC 2109 cookie标准的一部分,也不是所有浏览器都一致支持它。但是,当它设置时,它可能是一种降低客户端脚本访问受保护cookie数据的风险的有用方法。

使用samesite='Strict'或samesite='Lax'告诉浏览器在执行跨源请求时不要发送此cookie。并不是所有浏览器都支持SameSite。

HttpResponse.set_signed_cookis():与set_cookie()类似,但是在设置cookie之前对其进行加密签名。与HttpRequest.get_signed_cookie()一起使用。您可以使用可选的salt参数来添加键强度,但是您需要记住将它传递给相应的HttpRequest.get_signed_cookie()调用。

HttpResponse.delete_cookie(key,path='/',domain=None):即使cookie不存在也不会被删除。由于cookie的工作方式,路径和域应该与在set_cookie()中使用的值相同——否则cookie可能不会被删除。


四、HttpResponse子类

HttpResponseRedirect():返回状态码302参数url,响应将会被重定向到url

HttpResponsePermanentRedirect():状态码302永久重定向到某个url

HttpResponseNotModified():构造函数不接受任何参数,并且不应该向该响应添加任何内容。使用它可以指定自用户上次请求(状态代码304)以来页面没有被修改。

HttpResponseBadRequest():状态码400,请求错误

HttpResponseNotFound():状态码404,请求出错,页面找不到

HttpResponseForbidden():状态码403

HttpResponseServerError():状态码500,服务器内部错误

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django中,request对象是在Django的HTTP请求处理流程中创建的。具体来说,request对象是在WSGIHandler的get_response方法中创建的,而get_response方法是在Django应用程序接收到HTTP请求后被调用的。在get_response方法中,WSGIHandler首先调用中间件处理器(Middleware)来对request对象进行处理,然后根据URLConf将请求路由到相应的视图函数中。在路由到视图函数之前,WSGIHandler还会对request对象进行一些其他处理,比如将协议头(如HTTP头)中的信息添加到request对象中。 下面是WSGIHandler的get_response方法的代码片段,可以看到在该方法最开始的位置就创建了request对象: def get_response(self, request): # Setup default url resolver set_urlconf(settings.ROOT_URLCONF) # Reset url resolver cache if requested if getattr(request, '_wsgi_request', None): clear_url_caches() # Apply request middleware response = self.apply_request_middleware(request) if response: # If a middleware returns a response, run it right here! response._handler_class = None return response # Resolve the request resolver = get_resolver(get_urlconf(), subdomain=request.get_host().split(':')[0]) callback, callback_args, callback_kwargs = resolver.resolve(request.path_info) request.resolver_match = ResolverMatch(callback, callback_args, callback_kwargs, None) # Apply view middleware response = self.apply_view_middleware(request, callback, callback_args, callback_kwargs) if response: # If a middleware returns a response, run it right here! response._handler_class = None return response try: response = callback(request, *callback_args, **callback_kwargs)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值