1 http請求中產(chǎn)生的兩個核心對象
請求和響應(yīng)
http請求:HttpRequest
http響應(yīng):HttpResponse
2 HttpRequest 和 HttpResponse的屬性和方法
所在位置:django.http
2.1 HttpRequest:
HttpRequest對象的屬性:
Attribute | Description |
---|---|
path | 請求頁面的全路徑,不包括域名—例如, "/music/bands/the_beatles/"。 |
method | 請求中使用的HTTP方法的字符串表示。全大寫表示。例如:if request.method == 'GET': do_something()elif request.method == 'POST': do_something_else() |
GET | 包含所有HTTP GET參數(shù)的類字典對象。參見QueryDict 文檔。表單用get提交的,view中要用get方法接收,post也類似 |
POST | 包含所有HTTP POST參數(shù)的類字典對象。參見QueryDict 文檔。服務(wù)器收到空的POST請求的情況也是有可能發(fā)生的。也就是說,表單form通過HTTP POST方法提交請求,但是表單中可以沒有數(shù)據(jù)。因此,不能使用語句if request.POST來判斷是否使用HTTP POST方法;應(yīng)該使用if request.method == "POST" (參見本表的method屬性)。注意: POST不包括file-upload信息。參見FILES屬性。 |
REQUEST | 為了方便,該屬性是POST和GET屬性的集合體,但是有特殊性,先查找POST屬性,然后再查找GET屬性。借鑒PHP’s $_REQUEST。例如,如果GET = {"name": "john"} 和POST = {"age": '34'},則 REQUEST["name"] 的值是"john", REQUEST["age"]的值是"34".強烈建議使用GET and POST,因為這兩個屬性更加顯式化,寫出的代碼也更易理解。REQUEST這個屬性在django1.9里面已經(jīng)被移除掉了 |
COOKIES | 包含所有cookies的標(biāo)準(zhǔn)Python字典對象。Keys和values都是字符串。參見第12章,有關(guān)于cookies更詳細的講解。 |
FILES | 包含所有上傳文件的類字典對象。FILES中的每個Key都是<input type="file" name="" />標(biāo)簽中name屬性的值. FILES中的每個value 同時也是一個標(biāo)準(zhǔn)Python字典對象,包含下面三個Keys:filename: 上傳文件名,用Python字符串表示;content-type: 上傳文件的Content type;content: 上傳文件的原始內(nèi)容。注意:只有在請求方法是POST,并且請求頁面中<form>有enctype="multipart/form-data"屬性時FILES才擁有數(shù)據(jù)。否則,F(xiàn)ILES 是一個空字典。 |
META | 包含所有可用HTTP頭部信息的字典。 例如:CONTENT_LENGTH;CONTENT_TYPE;QUERY_STRING: 未解析的原始查詢字符串;REMOTE_ADDR: 客戶端IP地址;REMOTE_HOST: 客戶端主機名;SERVER_NAME: 服務(wù)器主機名;SERVER_PORT: 服務(wù)器端口。META 中這些頭加上前綴HTTP_最為Key, 例如:HTTP_ACCEPT_ENCODING;HTTP_ACCEPT_LANGUAGE;HTTP_HOST: 客戶發(fā)送的HTTP主機頭信息;HTTP_REFERER: referring頁;HTTP_USER_AGENT: 客戶端的user-agent字符串;HTTP_X_BENDER: X-Bender頭信息; |
user | 是一個django.contrib.auth.models.User 對象,代表當(dāng)前登錄的用戶。如果訪問用戶當(dāng)前沒有登錄,user將被初始化為django.contrib.auth.models.AnonymousUser的實例。你可以通過user的is_authenticated()方法來辨別用戶是否登錄:if request.user.is_authenticated(): # Do something for logged-in users.else: # Do something for anonymous users。只有激活Django中的AuthenticationMiddleware時該屬性才可用 |
session | 唯一可讀寫的屬性,代表當(dāng)前會話的字典對象。只有激活Django中的session支持時該屬性才可用。 參見第12章。 |
raw_post_data | 原始HTTP POST數(shù)據(jù),未解析過。 高級處理時會有用處。 |
get_full_path() | 返回包含查詢字符串的請求路徑。例如, "/music/bands/the_beatles/?print=true" |
2.2 QueryDict對象
get()
如果key對應(yīng)多個value,get()返回最后一個value。
在HttpRequest對象中, GET和POST屬性是django.http.QueryDict類的實例。
2.3 HttpResponse
對于HttpRequest 對象來說,是由Django自動創(chuàng)建, 但是,HttpResponse對象就必須我們自己創(chuàng)建。每個View請求處理方法必須返回一個HttpResponse對象。如果沒有返回,則會捕獲valueerror異常
HttpResponse類在django.http.HttpResponse。
2.3.1 構(gòu)造HttpResponse
>>> response = HttpResponse("Here's the text of the Web page.")
>>> response = HttpResponse("Text only, please.", mimetype="text/plain")
2.3.2 HttpResponse的子類(部分):
Class | Description |
---|---|
HttpResponseRedirect | 構(gòu)造函數(shù)接受單個參數(shù):重定向到的URL。可以是全URL (e.g., 'http://search.yahoo.com/')或者相對URL(e.g., '/search/'). 注意:這將返回HTTP狀態(tài)碼302。 |
HttpResponsePermanentRedirect | 同HttpResponseRedirect一樣,但是返回永久重定向(HTTP 狀態(tài)碼 301)。 |
HttpResponseNotFound | 返回404 status code. |
JsonResponse | 返回Json字符串。 |
2.3.3 在HttpResponse對象上擴展的常用方法
render、render_to_response、redirect
render其實是幾行代碼的簡寫,render_to_response更加簡潔,把render的request參數(shù)也省略了
更多詳見:HttpResponse對象上擴展的常用方法shortcuts
2.3.4 其他常用方法
locals(): 可以直接將函數(shù)中所有的變量全部傳給模板,自動拼接成字典,很方便。但是它會多傳遞一些沒用的變量,有點浪費