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

首頁 > 編程 > Python > 正文

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

2019-11-25 17:10:19
字體:
來源:轉載
供稿:網友

從Request對象中獲取數據

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

from django.http import HttpResponsedef hello(request):  return HttpResponse("Hello world")

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

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

2015717145228518.jpg (703×207)

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

# BAD!def current_url_view_bad(request):  return HttpResponse("Welcome to the page at /current/")# GOODdef current_url_view_good(request):  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() 方法來處理這些“可能不存在的鍵”:

# BAD!def ua_display_bad(request):  ua = request.META['HTTP_USER_AGENT'] # Might raise KeyError!  return HttpResponse("Your browser is %s" % ua)# GOOD (VERSION 1)def ua_display_good1(request):  try:    ua = request.META['HTTP_USER_AGENT']  except KeyError:    ua = 'unknown'  return HttpResponse("Your browser is %s" % ua)# GOOD (VERSION 2)def ua_display_good2(request):  ua = request.META.get('HTTP_USER_AGENT', 'unknown')  return HttpResponse("Your browser is %s" % ua)

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

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 普宁市| 棋牌| 瓦房店市| 荣昌县| 广饶县| 盐亭县| 沙洋县| 平阳县| 工布江达县| 马公市| 西乡县| 奉节县| 石狮市| 瓦房店市| 电白县| 淮阳县| 临汾市| 读书| 瓮安县| 金门县| 治多县| 葵青区| 蒙城县| 高雄市| 浙江省| 齐河县| 科尔| 康平县| 广东省| 钦州市| 永福县| 四会市| 茌平县| 江城| 获嘉县| 辽中县| 凤阳县| 五华县| 遂平县| 遂昌县| 莒南县|