• 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树。
  • 相关阅读:
    MySQL(2)---Explain
    MySQL(1)---索引
    php 的 PHPExcel1.8.0 使用教程
    通过html5 的EventSource来进行数据推送
    centos6.6 下 安装 php7 按 nginx方式
    IIS PHP Warning: Unknown: open(c:\php\tmp\sess_xxx, O_RDWR) failed: Permission denied (13) in Unknown on line 0
    动态加载JS,并执行回调函数
    nginx 504 gateway time out
    php 账号不能同时登陆,当其它地方登陆时,当前账号失效
    php 函数中静态变量的问题
  • 原文地址:https://www.cnblogs.com/juteng/p/11375406.html
Copyright © 2020-2023  润新知