Django请求响应对象
請(qǐng)求與響應(yīng)對(duì)象
HttpRequest
HttpRequest存儲(chǔ)了客戶請(qǐng)求的相關(guān)參數(shù)和一些查詢方法。
- path
請(qǐng)求頁面的全路徑,不包括域名—例如, "/hello/"。
- method
Http請(qǐng)求方法,包括'GET','POST'。
- GET
QueryDict類實(shí)例,包含所有HTTP GET參數(shù)的字典對(duì)象。
- POST
QueryDict類實(shí)例,包含所有HTTP POST參數(shù)的字典對(duì)象。
- REQUEST
為了方便,該屬性是POST和GET屬性的集合。
- COOKIES
包含所有Cookies的標(biāo)準(zhǔn)Python字典對(duì)象,Keys和Values都是字符串。
HttpRequest.get_signed_cookie(key, default=RAISE_ERROR, salt='', max_age=None)
返回簽名過的Cookie 對(duì)應(yīng)的值,如果簽名不再合法則返回django.core.signing.BadSignature。如果提供default 參數(shù),將不會(huì)引發(fā)異常并返回default 的值。
可選參數(shù)salt可以用來對(duì)安全密鑰強(qiáng)力攻擊提供額外的保護(hù)。
max_age參數(shù)用于檢查Cookie 對(duì)應(yīng)的時(shí)間戳以確保Cookie 的時(shí)間不會(huì)超過max_age秒。
HttpRequest.session.set_test_cookie() 設(shè)置測試cookie,檢驗(yàn)客戶端是否支持cookie
HttpRequest.session.test_cookie_worked() 檢測測試cookie,客戶端支持時(shí)返回True。
在set_test_cookie的同一次請(qǐng)求-響應(yīng)中test_cookie_worked的結(jié)果是不可靠的。
- FILES
包含所有上傳文件的類字典對(duì)象。
FILES中的每個(gè)Key都是<input type="file" name="" />標(biāo)簽中name屬性的值,FILES中的每個(gè)value 同時(shí)也是一個(gè)標(biāo)準(zhǔn)Python字典對(duì)象,包含3個(gè)Key:
"filename"
"content-type"
"content"
- META
包含所有可用HTTP頭信息的字典,其中的Key包括:
HTTP_ACCEPT_ENCODING
HTTP_ACCEPT_LANGUAGE
HTTP_HOST: 客戶發(fā)送的HTTP主機(jī)頭信息
HTTP_REFERER: referring頁
HTTP_USER_AGENT: 客戶端的user-agent字符串
HTTP_X_BENDER: X-Bender頭信息
- session
可讀寫的session對(duì)象
- raw_post_data
原始的POST數(shù)據(jù)
- 其它
HttpRequest.is_secure()請(qǐng)求是否由Https協(xié)議發(fā)起
HttpRequest.is_ajax() 請(qǐng)求是否由Ajax協(xié)議發(fā)起
QueryDict
HttpRequest中的GET和POST屬性都是django.http.QueryDict類的實(shí)例,它是dict派生類。提供了對(duì)一鍵多值的支持和相關(guān)操作方法。
HttpResponse
- content
HttpResponsee.content是存儲(chǔ)響應(yīng)內(nèi)容的字符串,
- item
HttpResponse.__setitem__(header, value) 設(shè)置響應(yīng)頭屬性
HttpResponse.__delitem__(header) 刪除響應(yīng)頭屬性
HttpResponse.__getitem__(header) 訪問響應(yīng)頭屬性
HttpResponse.has_header(header) 檢查是否存在響應(yīng)頭屬性
- cookie
HttpResponse.set_cookie(key, value='', max_age=None, expires=None, path='/', domain=None, secure=None, httponly=False) 設(shè)置cookie
HttpResponse.delete_cookie(key, path='/', domain=None) 刪除cookie
HttpResponse.set_signed_cookie(key, value, salt='', max_age=None, expires=None, path='/', domain=None, secure=None, httponly=True) 使用帶有密鑰簽名的數(shù)據(jù)
JsonResponse
JsonResponse是HttpResponse的子類,用于生成一個(gè)Json格式而非html/xml的響應(yīng)。
JsonResponse.__init__(data, encoder=DjangoJSONEncoder, safe=True, **kwargs)
在safe參數(shù)為True時(shí),只接受dict對(duì)象作為參數(shù),并將Dict作為Json字符串;在safe=False時(shí)使用ncoder=django.core.serializers.json.DjangoJSONEncoder參數(shù)指定的encoder。
from django.http import JsonResponsedef test_json(request):response = JsonResponse({'foo': 'bar'})return responseTemplateResponse
總結(jié)
以上是生活随笔為你收集整理的Django请求响应对象的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java cxf实现webserv
- 下一篇: lvs-健康检查方式