django開發系列:視圖高級之WSGIRequest對象和QueryDict對象
WSGIRequest對象
Django在接收到http請求之後,會根據http請求攜帶的參數以及報文信息創建一個WSGIRequest
對象,並且作爲視圖函數第一個參數傳給視圖函數。也就是我們經常看到的request參數。該類繼承於HttpRequst在這個對象上我們可以找到客戶端上傳上來的所有信息。這個對象的完整路徑是django.core.handlers.wsgi.WSGIRequest
。
WSGIRequest對象常用屬性
WSGIRequest對象上大部分的屬性都是隻讀的。因爲這些屬性是從客戶端上傳上來的,沒必要做任何的修改。以下將對一些常用的屬性進行講解:
-
path
:請求服務器的完整“路徑”,但不包含域名和參數。比如http://www.baidu.com/xxx/yyy/,那麼path就是/xxx/yyy/。 -
method
:代表當前請求的http方法。比如是GET還是POST。 -
GET
:一個django.http.request.QueryDict對象。操作起來類似於字典。這個屬性中包含了所有以?xxx=xxx的方式上傳上來的參數,可以用request.GET.get(“key_name”)來獲取。 -
POST
:也是一個django.http.request.QueryDict對象。這個屬性中包含了所有以POST方式上傳上來的參數。 -
FILES
:也是一個django.http.request.QueryDict對象。這個屬性中包含了所有上傳的文件。 -
COOKIES
:一個標準的Python字典,包含所有的cookie,鍵值對都是字符串類型。 -
session
:一個類似於字典的對象。用來操作服務器的session。 -
META
:存儲的客戶端發送上來的所有header信息,可用字典方法。CONTENT_LENGTH
:請求的正文的長度(是一個字符串)。CONTENT_TYPE
:請求的正文的MIME類型。HTTP_ACCEPT
:響應可接收的Content-Type。HTTP_ACCEPT_ENCODING
:響應可接收的編碼。HTTP_ACCEPT_LANGUAGE
: 響應可接收的語言。HTTP_HOST
:客戶端發送的HOST值。HTTP_REFERER
:在訪問這個頁面上一個頁面的url。QUERY_STRING
:單個字符串形式的查詢字符串(未解析過的形式)REMOTE_ADDR
:客戶端的IP地址。如果服務器使用了nginx做反向代理或者負載均衡,那麼這個值返回的是127.0.0.1,這時候可以使用HTTP_X_FORWARDED_FOR來獲取,所以獲取ip地址的代碼片段如下:
if request.META.has_key('HTTP_X_FORWARDED_FOR'):
ip = request.META['HTTP_X_FORWARDED_FOR']
else:
ip = request.META['REMOTE_ADDR']
REMOTE_HOST
:客戶端的主機名。REQUEST_METHOD
:請求方法。一個字符串類似於GET或者POST。SERVER_NAME
:服務器域名。SERVER_PORT
:服務器端口號,是一個字符串類型。
WSGIRequest對象常用方法
1.is_secure()
:是否是採用https協議。
2. is_ajax()
:是否採用ajax發送的請求。原理就是判斷請求頭中是否存在X-Requested-With:XMLHttpRequest這個鍵值對。
3. get_host()
:服務器的域名。如果在訪問的時候還有端口號,那麼會加上端口號。比如www.baidu.com:9000。
4. get_full_path()
:返回完整的path。如果有查詢字符串,還會加上查詢字符串。比如/music/bands/?print=True。
5. get_raw_uri()
:獲取請求的完整url。
QueryDict對象
from django.http.request import QueryDict
- 我們平時用的
request.GET
和request.POST
都是QueryDict對象
,這個對象繼承自dict,因此用法跟dict相差無幾。其中用得比較多的是get方法和getlist方法。
get方法
:用來獲取指定key的值,如果沒有這個key,那麼會返回None。可以指定default=xxx參數
getlist方法
:如果瀏覽器上傳上來的key對應的值有多個,那麼就需要通過這個方法獲取。返回一個列表