国产探花免费观看_亚洲丰满少妇自慰呻吟_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 對象的其它方法加進去。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 桐城市| 介休市| 岳普湖县| 兴海县| 简阳市| 晋州市| 揭西县| 布尔津县| 彩票| 宜昌市| 女性| 周宁县| 武功县| 辽宁省| 松滋市| 松阳县| 长海县| 阿克陶县| 房产| 砚山县| 安溪县| 驻马店市| 东安县| 金溪县| 安多县| 巴林左旗| 铁岭市| 大埔县| 洪洞县| 安岳县| 广丰县| 东平县| 黄陵县| 香河县| 安国市| 赤水市| 静乐县| 桐城市| 尉氏县| 辛集市| 玉门市|