request
根据请求的信息获取base url(有时候服务的域名比较多,还是需要动态的拼接一下url信息)
# url http://wificdn:8888/wxpay/qrcode2/16122010404238801544?name=lzz
request.get_host() # wificdn:8888
request.get_full_path() # u'/wxpay/qrcode2/16122010404238801544?name=lzz'
request.build_absolute_uri('/') # 'http://wificdn:8888/'
request.build_absolute_uri('/hello') # 'http://wificdn:8888/hello'
request.build_absolute_uri() # 'http://wificdn:8888/wxpay/qrcode2/16122010404238801544?name=lzz'
request.path # u'/wxpay/qrcode2/16122010404238801544'
request.scheme # 'http'
第二种方法获取绝对路径方法:
使用工具 django-absoluteuri 1.2.0
安装:
pip install django-absoluteuri
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树。
更多推荐
Django request各种操作
发布评论