当前位置 主页 > 服务器问题 > Linux/apache问题 >
本文实例讲述了Django框架HttpRequest对象用法。分享给大家供大家参考,具体如下:
(1)位置参数:使用正则分组,与视图中的参数一一对应,不可换位置
例:
url(r'^(\d+)/(\d+)/$', views.index) def index(request, 参数1, 参数2): ...
(2)关键字参数:参数位置可以变,与关键字保持一致即可
例:
url(r'^(?P<value1>\d+)/(?P<value2>\d+)/$', views.index) def index(request, value2, value1): ...
HttpRequest对象的属性GET、POST都是QueryDict类型的对象,,QueryDict可以处理一键多值的问题。
(1)get:根据键获取值,如果有多个值,则获取最后一个。
get('键', 默认值)
(2)getlist:根据键获取值,值为列表形式。
getlist('键', 默认值)
请求路径中的查询字符串(?k1=1&k2=v2…),可通过request.GET来获取,返回QueryDict对象。(不区分请求方式,POST也可用GET来获取)
例:
# /get/?a=1&b=2&a=3 def get(request): a = request.GET.get('a') b = request.GET.get('b') alist = request.GET.getlist('a') print(a) # 3 print(b) # 2 print(alist) # ['1', '3'] return HttpResponse('OK')
(1)表单类型Form Data:
通过request.POST.get()来获取
(2)非表单类型Non-Form Data:
非表单类型数据,Django无法自动解析,可以填先通过request.body获取数据,然后按照请求格式解析
例:
import json def post_json(request): json_str = request.body # 获取请求体数据 json_str = json_str.decode() # 解码,python3.6 无需执行此步 req_data = json.loads(json_str) # 将json转为字典 print(req_data['a']) # 获取字典值 print(req_data['b']) return HttpResponse('OK')
可通过request.META来获取请求头信息,类型为字典类型
参数 | 描述 |
---|---|
method | 一个字符串,表示请求使用的HTTP方法,常用值包括:‘GET'、‘POST'。 |
use | 请求的用户对象。 |
path | 一个字符串,表示请求的页面的完整路径,不包含域名和参数部分。 |
encoding | 一个字符串,表示提交的数据的编码方式。 |
FILES | 一个类似于字典的对象,包含所有的上传文件。 |
希望本文所述对大家基于Django框架的Python程序设计有所帮助。