国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

詳解Django中Request對象的相關用法

2020-01-04 18:02:50
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了詳解Django中Request對象的相關用法,Django是Python重多人氣框架中最著名的一個,需要的朋友可以參考下

從Request對象中獲取數據

我們在第三章講述View的函數時已經介紹過HttpRequest對象了,但當時并沒有講太多。 讓我們回憶下:每個view函數的第一個參數是一個HttpRequest對象,就像下面這個hello()函數:

 

 
  1. from django.http import HttpResponse 
  2.  
  3. def hello(request): 
  4. return HttpResponse("Hello world"

HttpRequest對象,比如上面代碼里的request變量,會有一些有趣的、你必須讓自己熟悉的屬性和方法,以便知道能拿它們來做些什么。 在view函數的執行過程中,你可以用這些屬性來獲取當前request的一些信息(比如,你正在加載這個頁面的用戶是誰,或者用的是什么瀏覽器)。

URL相關信息

HttpRequest對象包含當前請求URL的一些信息:

詳解Django中Request對象的相關用法

在view函數里,要始終用這個屬性或方法來得到URL,而不要手動輸入。 這會使得代碼更加靈活,以便在其它地方重用。 下面是一個簡單的例子:

 

 
  1. # BAD! 
  2. def current_url_view_bad(request): 
  3. return HttpResponse("Welcome to the page at /current/"
  4.  
  5. # GOOD 
  6. def current_url_view_good(request): 
  7. return HttpResponse("Welcome to the page at %s" % request.path) 

有關request的其它信息

request.META 是一個Python字典,包含了所有本次HTTP請求的Header信息,比如用戶IP地址和用戶Agent(通常是瀏覽器的名稱和版本號)。 注意,Header信息的完整列表取決于用戶所發送的Header信息和服務器端設置的Header信息。 這個字典中幾個常見的鍵值有:

HTTP_REFERER,進站前鏈接網頁,如果有的話。 (請注意,它是REFERRER的筆誤。)

HTTP_USER_AGENT,用戶瀏覽器的user-agent字符串,如果有的話。 例如: "Mozilla/5.0 (X11; U; Linux i686; fr-FR; rv:1.8.1.17) Gecko/20080829 Firefox/2.0.0.17" .

REMOTE_ADDR 客戶端IP,如:"12.345.67.89" 。(如果申請是經過代理服務器的話,那么它可能是以逗號分割的多個IP地址,如:"12.345.67.89,23.456.78.90" 。)

注意,因為 request.META 是一個普通的Python字典,因此當你試圖訪問一個不存在的鍵時,會觸發一個KeyError異常。 (HTTP header信息是由用戶的瀏覽器所提交的、不應該給予信任的“額外”數據,因此你總是應該好好設計你的應用以便當一個特定的Header數據不存在時,給出一個優雅的回應。)你應該用 try/except 語句,或者用Python字典的 get() 方法來處理這些“可能不存在的鍵”:

 

 
  1. # BAD! 
  2. def ua_display_bad(request): 
  3. ua = request.META['HTTP_USER_AGENT'] # Might raise KeyError! 
  4. return HttpResponse("Your browser is %s" % ua) 
  5.  
  6. # GOOD (VERSION 1) 
  7. def ua_display_good1(request): 
  8. try
  9. ua = request.META['HTTP_USER_AGENT'
  10. except KeyError: 
  11. ua = 'unknown' 
  12. return HttpResponse("Your browser is %s" % ua) 
  13.  
  14. # GOOD (VERSION 2) 
  15. def ua_display_good2(request): 
  16. ua = request.META.get('HTTP_USER_AGENT''unknown'
  17. return HttpResponse("Your browser is %s" % ua) 

我們鼓勵你動手寫一個簡單的view函數來顯示 request.META 的所有數據,這樣你就知道里面有什么了。 這個view函數可能是這樣的:

 

 
  1. def display_meta(request): 
  2. values = request.META.items() 
  3. values.sort() 
  4. html = [] 
  5. for k, v in values: 
  6. html.append('<tr><td>%s</td><td>%s</td></tr>' % (k, v)) 
  7. return HttpResponse('<table>%s</table>' % '/n'.join(html)) 

做為一個練習,看你自己能不能把上面這個view函數改用Django模板系統來實現,而不是上面這樣來手動輸入HTML代碼。 也可以試著把前面提到的 request.path 方法或 HttpRequest 對象的其它方法加進去。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 虎林市| 钦州市| 克拉玛依市| 紫金县| 临清市| 和田县| 屯门区| 丘北县| 香港 | 峨边| 南川市| 留坝县| 连江县| 贵州省| 渝中区| 河池市| 罗源县| 沧州市| 历史| 亳州市| 红桥区| 石城县| 甘洛县| 嘉义县| 宜春市| 黔东| 泗洪县| 涟水县| 三门县| 碌曲县| 呈贡县| 广德县| 贺兰县| 什邡市| 固安县| 微山县| 六盘水市| 连南| 南安市| 贡嘎县| 象山县|