Django中的request对象和response对象(简单整理)

时间:2019-08-19
本文章向大家介绍Django中的request对象和response对象(简单整理),主要包括Django中的request对象和response对象(简单整理)使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

对Django中的request对象和response对象做一个简单的总结。

request和response在Django中的作用:

  django使用request对象和response对象在系统间传递状态。当请求一个页面的时候,django会建立一个包含请求元数据的HttpRequest对象,当django加载对应的视图时,HttpRequest对象将作为视图函数的第一个参数,每个视图会返回一个HttpResponse对象,当然也有例外,以后在讨论这种情况。
reqeust对象中的基本属性:
    request.scheme --> 返回一个字符串,表示请求方案
    request.body   --> 返回一个字符串,表示原始http请求的正文
    request.path   --> 返回一个字符串,表示请求页面的完整路径,不包含域名
    reqeust.path_info --> path_info属性始终包含路径信息部分,不论使用的web服务器是什么,使用它代替path可以让代码在测试和开发环境中更容易切换
    requst.method --> 返回一个字符串,表示你请求使用的http方法,必须使用大写
    request.encoding --> 返回一个字符串,表示提交的数据的编码方式,(如果为None,则表示使用default_charset设置),默认是utf-8,这个属性是可写的
    request.GET/POST -->返回的是一个类字典的对象,包含HTTP GET的所有参数/POST的参数
    request.COOKIES --> 返回一个标准的字典,包含所有的cookie,键和值都是字符串
    request.FILES --> 一个类似于字典的对象,包含所有的上传文件,files中的每一键为<input type="file" name=""/>中的name,
        files只有在请求的方法为post并且提交的form带有enctype="multipart/form-data"的情况下才会包含数据,否则,file将为一个空的类似于字典的对象
    request.META --> 返回一个标准的字典,包含所有的http头部
    reqeust.user --> 返回一个auth_user_model类
    request.session --> 一个既可读又可写的类字典对象,表示当前的会话,只有当django启用会话的支持的时候才可用
    reqeust.urlconf --> 不是由Django 自身定义的,但是如果其它代码(例如,自定义的中间件类)设置了它,Django 就会读取它。如果存在,它将用来作为当前的请求的Root URLconf,
 并覆盖ROOT_URLCONF 设置
    request.resolver_match --> 一个ResolverMatch 的实例,表示解析后的URL。
        这个属性只有在URL 解析方法之后才设置,这意味着它在所有的视图中可以访问,但是在在URL 解析发生之前执行的中间件方法中不可以访问(比如process_request,
  但你可以使用process_view 代替)    

request对象中的方法:

    request.get_host():返回请求的主机,如果主机位于多个代理的后面,那么get_host()失效
    request.get_full_path():返回path,如果可以将加上查询字符串
        例子:
            "music/band/?print=true"
    reqeust.build_absolute_uri(location):返回location的绝对url,如果location没有提供,那么设置为request.get_full_path(),如果URI已经是一个绝对的URI,
 将不会修改。否则,使用请求中的服务器相关的变量构建绝对URI。
    request.get_signed_cookie(key, default=RAISE_ERROR, salt='', max_age=None)
            返回签名过的Cookie 对应的值,如果签名不再合法则返回django.core.signing.BadSignature。如果提供default 参数,将不会引发异常并返回default 的值。
            可选参数salt 可以用来对安全密钥强力攻击提供额外的保护。max_age 参数用于检查Cookie 对应的时间戳以确保Cookie 的时间不会超过max_age 秒。
    request.is_secure():如果请求是安全的,则返回True,也就是请求是通过https发起的
    reqeust.is_ajax():如果请求是通过XMLHttpRequest 发起的,则返回True
    reqeust.read(size=None)
    reqeust.readline()
    reqeust.readlines()
    reqeust.xreadlines()
    reqeust.__iter__()
    这几个方法实现类文件的接口用于读取HttpRequest· 实例。这使得可以用流的方式读取进来的请求。一个常见的用例是使用迭代解析器处理大型XML有效载荷,而不在内存中构造一个完整的XML树。

原文地址:https://www.cnblogs.com/juteng/p/11375406.html