Django框架HttpResponse和HttpRequest對象學習
HttpRequest對象
在前面你也跟著本博主編寫了那么多的視圖函數(shù),但是每個視圖函數(shù)它都會接收一個名為request的參數(shù)。
是不是很好奇:視圖函數(shù)接收到的request到底是個什么對象?。?!

1.我們可以打印這個request對象
看一下:
<WSGIRequest: GET '/music/test3/'>
我們知道WSGIRequest是一個HTTP請求對象,里面包括了提交的方式和URL路徑。
綜上可知:
服務器接收到http協(xié)議的請求后,會根據(jù)報文創(chuàng)建HttpRequest對象
它是一個請求對象:用戶信息(提交方式等);瀏覽器信息(請求頭信息等)。
視圖函數(shù)的第一個參數(shù)是HttpRequest對象。
在django.http模塊中定義了HttpRequest對象的API
2.我們可以打印觀察一下它具備哪些方法
dir(request)

常用屬性和方法功能講解:
屬性:
path:一個字符串,表示請求的頁面的完整路徑,不包含域名。method:一個字符串,表示請求使用的HTPP方法,常用的值包括:‘GET',‘POST'。encoding:一個字符串,表示提交的數(shù)據(jù)的編碼方式。如果為None則表示使用瀏覽器的默認設置(一般為utf-8)。這個屬性是可寫的,可以通過修改它來修改訪問表單數(shù)據(jù)使用的編碼,加下來對屬性的任何訪問都將使用新的encoding值。GET:一個類似于字典的對象,包含get請求方式的所有參數(shù)。POST:一個類似于字典的對象,包含post請求方式的所有參數(shù)。FILES:一個類似于字典的對象,包含所有的上傳文件。COOKIES:一個標準的Python字典,包含所有的cookie,鍵和值都為字符串。session:一個既可讀又可寫的類似于字典的對象,表示當前的會話,只有當Django啟用會話的支持時才可用。
方法:
is_ajax():如果請求是通過XMDHttpRequest發(fā)起的,則返回True。
HttpResponse對象
很多時候我們在訪問網頁的時候,網頁的開發(fā)者為了美觀,大多數(shù)都是使用JS效果來顯示諸如彈窗之類的效果(提醒登錄呀/提醒注冊呀/該用戶名已經注冊呀之類的)
那么,使用Django如何實現(xiàn)JS效果呢?
Django服務器接收到客戶端發(fā)送過來的請求后,會將提交上來的這些數(shù)據(jù)封裝成一個HttpRequest對象傳給視圖函數(shù)。那么視圖函數(shù)在處理完相關的邏輯后,也需要返回一個響應給瀏覽器。而這個響應,我們必須返回HttpResponseBase或者他的子類的對象。而HttpResponse則是HttpResponseBase用得最多的子類。那么接下來就來介紹一下HttpResponse及其子類。
HttpResponse對象的屬性和方法
屬性
content:表示返回的內容,字符串類型;
charset:表示response采用的編碼字符集,字符串類型;
status_code:響應的HTTP響應狀態(tài)碼;
content-type:返回的數(shù)據(jù)的MIME類型,默認為text/html。瀏覽器會根據(jù)這個屬性,來顯示數(shù)據(jù)。如果是text/html,那么就會解析這個字符串,如果text/plain,那么就會顯示一個純文本。常用的Content-Type如下:
- text/html(默認的,html文件)
- text/plain(純文本)
- text/css(css文件)
- text/javascript(js文件)
- multipart/form-data(文件提交)
- application/json(json傳輸)
- application/xml(xml文件)
示例:
response = HttpResponse('<h2>微信公眾號【孤寒者】</h1>',content_type='text/plain;charset=utf-8')
# 注意:一般在使用‘text/plain'時,都會添加‘charset=utf-8',否則是會亂碼的。
return response
方法
init:使用頁內容實例化HttpResponse對象;
write(content):以文件的方式寫;
flush():以文件的方式輸出緩存區(qū);
set_cookie(key, value='',max_age=None, expires=None):設置Cookie。
參數(shù)講解:
①key,value都是字符串類型;
②max_age是一個整數(shù),表示在指定秒數(shù)后過期;
③expires是一個datetime或timedelta對象,會話將在這個指定的日期/時間過期,注意datetime和timedelta值只有在使用PickleSerializer時才可序列化;
④max_age和expires二選一,如果不指定過期時間,則關閉瀏覽器就失效。
delete_cookie(key):刪除指定的key的cookie,如果Key不存在則什么也不發(fā)生。
HttpResponse的子類
返回數(shù)據(jù)的響應函數(shù)
- HttpResponse() 返回簡單的字符串對象
- render() 渲染模板
- redirect() 重定向
- JsonResponse() 返回json數(shù)據(jù)。結合前端AJax等技術可以實現(xiàn)后端向前端傳數(shù)據(jù),前端接收后實現(xiàn)諸如注冊登錄等的JS效果功能?。ㄟ@就解決了前面所說的問題?。?/li>
from django.http import JsonResponse
def resp(request):
return JsonResponse({'ss':'登錄成功!'})
# 幫助用戶創(chuàng)建JSON編碼的響應;
# 參數(shù)data是字典對象;
# JsonResponse的默認Content-Type為application/json。
以上就是Django框架HttpResponse和HttpRequest對象學習的詳細內容,更多關于Django框架HttpResponse和HttpRequest對象的資料請關注腳本之家其它相關文章!
相關文章
教你利用PyTorch實現(xiàn)sin函數(shù)模擬
這篇文章主要給大家介紹了關于教你利用PyTorch實現(xiàn)sin函數(shù)模擬的相關資料,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2022-01-01
python3模擬百度登錄并實現(xiàn)百度貼吧簽到示例分享(百度貼吧自動簽到)
這篇文章主要介紹了python3模擬百度登錄并實現(xiàn)百度貼吧簽到示例,需要的朋友可以參考下2014-02-02
Python實現(xiàn)WGS84火星百度及web墨卡托四種坐標系相互轉換
主流被使用的地理坐標系并不統(tǒng)一,常用的有WGS84、GCJ02(火星坐標系)、BD09(百度坐標系)以及百度地圖中保存矢量信息的web墨卡托,本文利用Python編寫相關類以實現(xiàn)4種坐標系統(tǒng)之間的互相轉換2023-08-08

