1. HttpRequest對象 伺服器接收到http協議的請求後,會根據報文創建HttpRequest對象,這個對象不需要我們創建,直接使用伺服器構造好的對象就可以。視圖的第一個參數必須是HttpRequest對象,在django.http模塊中定義了HttpRequest對象的API。 1.1 ...
1. HttpRequest對象
伺服器接收到http協議的請求後,會根據報文創建HttpRequest對象,這個對象不需要我們創建,直接使用伺服器構造好的對象就可以。視圖的第一個參數必須是HttpRequest對象,在django.http模塊中定義了HttpRequest對象的API。
1.1 屬性
path:一個字元串,表示請求的頁面的完整路徑,不包含功能變數名稱和參數部分。
method:一個字元串,表示請求使用的HTTP方法,常用值包括:'GET'、'POST'。
在瀏覽器中給出地址發出請求採用get方式,如超鏈接。
在瀏覽器中點擊表單的提交按鈕發起請求,如果表單的method設置為post則為post請求。
encoding:一個字元串,表示提交的數據的編碼方式。
如果為None則表示使用瀏覽器的預設設置,一般為utf-8。
這個屬性是可寫的,可以通過修改它來修改訪問表單數據使用的編碼,接下來對屬性的任何訪問將使用新的encoding值。
GET:QueryDict類型對象,類似於字典,包含get請求方式的所有參數。
POST:QueryDict類型對象,類似於字典,包含post請求方式的所有參數。
FILES:一個類似於字典的對象,包含所有的上傳文件。
COOKIES:一個標準的Python字典,包含所有的cookie,鍵和值都為字元串。
session:一個既可讀又可寫的類似於字典的對象,表示當前的會話,只有當Django 啟用會話的支持時才可用,詳細內容見"狀態保持"。
1.2 QueryDict對象
定義在django.http.QueryDict
HttpRequest對象的屬性GET、POST都是QueryDict類型的對象
與python字典不同,QueryDict類型的對象用來處理同一個鍵帶有多個值的情況
方法get():根據鍵獲取值
如果一個鍵同時擁有多個值將獲取最後一個值
如果鍵不存在則返回None值,可以設置預設值進行後續處理
dict.get('鍵',預設值) 可簡寫為 dict['鍵']
方法getlist():根據鍵獲取值,值以列表返回,可以獲取指定鍵的所有值
如果鍵不存在則返回空列表[],可以設置預設值進行後續處理
dict.getlist('鍵',預設值)
1.3 GET屬性
請求格式:在請求地址末尾使用?,之後以“鍵=值”的格式拆分,多個鍵值對之間以&連接。
例:網址如下
https://search.jd.com/Search?keyword=%E7%AC%94%E8%AE%B0%E6%9C%AC&enc=utf-8&wq=%E7%AC%94%E8%AE%B0%E6%9C%AC&pvid=e6ed133c7c1f4286b8579fed9c36e187
其中的請求參數為:
keyword=%E7%AC%94%E8%AE%B0%E6%9C%AC&enc=utf-8&wq=%E7%AC%94%E8%AE%B0%E6%9C%AC&pvid=e6ed133c7c1f4286b8579fed9c36e187
分析請求參數,鍵為'a','b','c',轉化為'10','20','python'。
在Django中可以使用HttpRequest對象的GET屬性獲得get方方式請求的參數。
GET屬性是一個QueryDict類型的對象,鍵和值都是字元串類型。
鍵是開發人員在編寫代碼時確定下來的。
值是根據數據生成的。
1.4 POST屬性
使用form表單請求時,方法方式為post繼承發起post方式的請求,需要使用HttpRequest對象的POST屬性接收參數,POST屬性是一個QueryDict類型的對象。
表單form如何提交參數呢?
表單控制項名稱屬性的值作為鍵,值屬性的變數值,構成鍵值對提交。
如果表單控制項沒有名稱屬性則不提交。
對於覆選框控制項,名稱屬性的值相同為一組,被指定的項會被提交,出現一鍵多值的情況。
鍵是表單控制項名稱屬性的值,是由開發人員編寫的。
值是用戶填寫或選擇的。
2. HttpResponse對象
視圖在接收請求並處理後,必須返回HttpResponse對象或子對象。在django.http模塊中定義了HttpResponse對象的API。HttpRequest對象由Django創建,HttpResponse對象由開發人員創建。
2.1 屬性
content:表示返回的內容。
charset:表示response採用的編碼字元集,預設為utf-8。
status_code:返回的HTTP響應狀態碼。
content-type:指定返回數據的的MIME類型,預設為'text/html'。
2.2 方法
_init_:創建HttpResponse對象後完成返回內容的初始化。
set_cookie:設置Cookie信息。
set_cookie(key, value='', max_age=None, expires=None)
cookie是網站以鍵值對格式存儲在瀏覽器中的一段純文本信息,用於實現用戶跟蹤。
max_age是一個整數,表示在指定秒數後過期。
expires是一個datetime或timedelta對象,會話將在這個指定的日期/時間過期。
max_age與expires二選一。
如果不指定過期時間,在關閉瀏覽器時cookie會過期。
delete_cookie(key):刪除指定的key的Cookie,如果key不存在則什麼也不發生。
write:向響應體中寫數據。
2.3 子類JsonResponse
在瀏覽器中使用javascript發起ajax請求時,返回json格式的數據,此處以jquery的get()方法為例。類JsonResponse繼承自HttpResponse對象,被定義在django.http模塊中,創建對象時接收字典作為參數。
JsonResponse對象的content-type為'application/json'。
2.4 子類HttpResponseRedirect
當一個邏輯處理完成後,不需要向客戶端呈現數據,而是轉回到其它頁面,如添加成功、修改成功、刪除成功後顯示數據列表,而數據的列表視圖已經開發完成,此時不需要重新編寫列表的代碼,而是轉到這個視圖就可以,此時就需要模擬一個用戶請求的效果,從一個視圖轉到另外一個視圖,就稱為重定向。
Django中提供了HttpResponseRedirect對象實現重定向功能,這個類繼承自HttpResponse,被定義在django.http模塊中,返回的狀態碼為302。
重定向簡寫函數redirect
在django.shortcuts模塊中為重定向類提供了簡寫函數redirect。
修改booktest/views.py文件中red1視圖,代碼如下:
from django.shortcuts import redirect ... def red1(request): return redirect('/')