目錄
- HttpRequest對象
- 1.我們可以打印這個request對象
- 2.我們可以打印觀察一下它具備哪些方法
- HttpResponse對象
- HttpResponse對象的屬性和方法
- HttpResponse的子類
- 返回數(shù)據(jù)的響應(yīng)函數(shù)
HttpRequest對象
在前面你也跟著本博主編寫了那么多的視圖函數(shù),但是每個視圖函數(shù)它都會接收一個名為request的參數(shù)。
是不是很好奇:視圖函數(shù)接收到的request到底是個什么對象?。?!
![](/d/20211017/e6bca87e8b649b912dd606d1695bcc1d.gif)
1.我們可以打印這個request對象
看一下:
WSGIRequest: GET '/music/test3/'>
我們知道WSGIRequest是一個HTTP請求對象,里面包括了提交的方式和URL路徑。
綜上可知:
服務(wù)器接收到http協(xié)議的請求后,會根據(jù)報文創(chuàng)建HttpRequest對象
它是一個請求對象:用戶信息(提交方式等);瀏覽器信息(請求頭信息等)。
視圖函數(shù)的第一個參數(shù)是HttpRequest對象。
在django.http模塊中定義了HttpRequest對象的API
2.我們可以打印觀察一下它具備哪些方法
![](/d/20211017/684b9507c7fd74bccbbf2c17f27ef9c6.gif)
常用屬性和方法功能講解:
屬性:
path
:一個字符串,表示請求的頁面的完整路徑,不包含域名。
method
:一個字符串,表示請求使用的HTPP方法,常用的值包括:‘GET',‘POST'。
encoding
:一個字符串,表示提交的數(shù)據(jù)的編碼方式。如果為None則表示使用瀏覽器的默認設(shè)置(一般為utf-8)。這個屬性是可寫的,可以通過修改它來修改訪問表單數(shù)據(jù)使用的編碼,加下來對屬性的任何訪問都將使用新的encoding值。
GET
:一個類似于字典的對象,包含get請求方式的所有參數(shù)。
POST
:一個類似于字典的對象,包含post請求方式的所有參數(shù)。
FILES
:一個類似于字典的對象,包含所有的上傳文件。
COOKIES
:一個標準的Python字典,包含所有的cookie,鍵和值都為字符串。
session
:一個既可讀又可寫的類似于字典的對象,表示當前的會話,只有當Django啟用會話的支持時才可用。
方法:
is_ajax()
:如果請求是通過XMDHttpRequest發(fā)起的,則返回True。
HttpResponse對象
很多時候我們在訪問網(wǎng)頁的時候,網(wǎng)頁的開發(fā)者為了美觀,大多數(shù)都是使用JS效果來顯示諸如彈窗之類的效果(提醒登錄呀/提醒注冊呀/該用戶名已經(jīng)注冊呀之類的)
那么,使用Django如何實現(xiàn)JS效果呢?
Django服務(wù)器接收到客戶端發(fā)送過來的請求后,會將提交上來的這些數(shù)據(jù)封裝成一個HttpRequest對象傳給視圖函數(shù)。那么視圖函數(shù)在處理完相關(guān)的邏輯后,也需要返回一個響應(yīng)給瀏覽器。而這個響應(yīng),我們必須返回HttpResponseBase或者他的子類的對象。而HttpResponse則是HttpResponseBase用得最多的子類。那么接下來就來介紹一下HttpResponse及其子類。
HttpResponse對象的屬性和方法
屬性
content
:表示返回的內(nèi)容,字符串類型;
charset
:表示response采用的編碼字符集,字符串類型;
status_code
:響應(yīng)的HTTP響應(yīng)狀態(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
:使用頁內(nèi)容實例化HttpResponse對象;
write(content)
:以文件的方式寫;
flush()
:以文件的方式輸出緩存區(qū);
set_cookie
(key, value='',max_age=None, expires=None):設(shè)置Cookie。
參數(shù)講解:
①key,value都是字符串類型;
②max_age是一個整數(shù),表示在指定秒數(shù)后過期;
③expires是一個datetime或timedelta對象,會話將在這個指定的日期/時間過期,注意datetime和timedelta值只有在使用PickleSerializer時才可序列化;
④max_age和expires二選一,如果不指定過期時間,則關(guān)閉瀏覽器就失效。
delete_cookie(key):刪除指定的key的cookie,如果Key不存在則什么也不發(fā)生。
HttpResponse的子類
返回數(shù)據(jù)的響應(yīng)函數(shù)
- HttpResponse() 返回簡單的字符串對象
- render() 渲染模板
- redirect() 重定向
- JsonResponse() 返回json數(shù)據(jù)。結(jié)合前端AJax等技術(shù)可以實現(xiàn)后端向前端傳數(shù)據(jù),前端接收后實現(xiàn)諸如注冊登錄等的JS效果功能!(這就解決了前面所說的問題?。?/li>
from django.http import JsonResponse
def resp(request):
return JsonResponse({'ss':'登錄成功!'})
# 幫助用戶創(chuàng)建JSON編碼的響應(yīng);
# 參數(shù)data是字典對象;
# JsonResponse的默認Content-Type為application/json。
以上就是Django框架HttpResponse和HttpRequest對象學習的詳細內(nèi)容,更多關(guān)于Django框架HttpResponse和HttpRequest對象的資料請關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:- Django框架HttpResponse對象用法實例分析
- Django框架HttpRequest對象用法實例分析
- Django的HttpRequest和HttpResponse對象詳解
- 詳解Django中Request對象的相關(guān)用法
- Django 響應(yīng)數(shù)據(jù)response的返回源碼詳解