亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区

當(dāng)前位置:首頁 > 網(wǎng)站舊欄目 > 學(xué)習(xí)園地 > 設(shè)計軟件教程 > 翻譯www.djangobook.com之第十六章:中間件

翻譯www.djangobook.com之第十六章:中間件
2010-01-13 23:43:58  作者:  來源:
有時你需要對每個Django處理的請求運行一段代碼,該代碼可能需要在視圖處理它之前修改請求,或者可能日志為了調(diào)試而
記錄關(guān)于請求的信息等等
Django的中間件框架本質(zhì)上是進入Django的請求/應(yīng)答處理的鉤子,它是全局改變Django的輸入和輸出的輕量的,低級的"插
件"系統(tǒng)
每個中間件組件負責(zé)一些專有的功能,如果你線性的閱讀本書,則你已經(jīng)看到中間件好幾次了:
1,我們在第12章看到的所有俏皮的會話和用戶工具可能由一些小塊的中間件構(gòu)成(更明確的,中間件使得你在視圖中可以得
到request.session和request.user)
2,第12章討論的站點寬度的緩存事實上只是一些中間件,如果視圖的應(yīng)答已經(jīng)被緩存則它們是調(diào)用你的視圖方法的捷徑
3,第15章的flatpages,redirects和csrf這些貢獻的apps都是通過使用中間件組件來施展它們的魔力
本章深入了解什么是中間件以及它怎樣工作,并解釋了你怎樣寫你自己的中間件

什么是中間件?
中間件事實上難以置信的簡單,一個中間件組件是簡單的遵守某一API的Python類--又是鴨子類型!在深入正式的API之前,讓
我們先來看看簡單的例子
高流量的站點通常需要在一個負載均衡代理后面部署Django(參考第12章),這會導(dǎo)致一些小的復(fù)雜性,其中一個是每個請求
的遠程IP(request.META["REMOTE_IP"])將為負載均衡者的IP,而不是真實的IP生成的請求,負載均衡通過設(shè)置特殊的頭部
X-Forwared-For到真實的請求IP地址來處理這些
所以這里是一些中間件讓代理后面運行的站點仍然可以在request.META["REMOTE_IP"]看到正確的IP地址:
Java代碼 復(fù)制代碼
  1. class SetRemoteAddrFromForwardedFor(object):   
  2.   
  3.     def process_request(self, request):   
  4.         try:   
  5.             real_ip = request.META['HTTP_X_FORWARDED_FOR']   
  6.         except KeyError:   
  7.             pass   
  8.         else:   
  9.             # HTTP_X_FORWARDED_FOR can be a comma-separated list of IPs.   
  10.             # Take just the first one.   
  11.             real_ip = real_ip.split(",")[0]   
  12.             request.META['REMOTE_ADDR'] = real_ip  

如果它被安裝了(參考下面的),每個請求的X-Forwarded-For值將被自動插入到request.META['REMOTE_ADDR'],很簡單吧?
事實上,這個中間件作為Django的內(nèi)建部分是一個足夠常見的需要,它位于django.middleware.http,你在下面可以看到一
些更多關(guān)于它的內(nèi)容

安裝中間件
線性閱讀的讀者可能已經(jīng)對此是老手了,如果你已經(jīng)指定怎樣激活中間件則前面的一些章節(jié)中的許多例子將很好的工作
盡管如此,為了完整性考慮--以及為了考慮那些已經(jīng)把本書的頁面撕破并攪亂它們并隨機閱讀它們的Julio Cortázar 迷們
讓我們來看看它
為了激活中間件組件,把它添加到你的settings模塊的MIDDLEWARE_CLASSES列表中,在MIDDLEWARE_CLASSES里,每個中間件
組件通過一個字符串來表示:完整的到中間件的類名的Python路徑,例如,這里是通過django-admin.py startproject創(chuàng)建的
默認的MIDDLEWARE_CLASSES:
Java代碼 復(fù)制代碼
  1. MIDDLEWARE_CLASSES = (   
  2.     'django.middleware.common.CommonMiddleware',   
  3.     'django.contrib.sessions.middleware.SessionMiddleware',   
  4.     'django.contrib.auth.middleware.AuthenticationMiddleware',   
  5.     'django.middleware.doc.XViewMiddleware',   
  6. )  

Django安裝部需要任何中間件--例如MIDDLEWARE_CLASSES可以為空,如果你想這樣的話--但是強烈建議你使用CommonMiddle
ware
順序是有意義的,在請求和視圖階段,Django使用MIDDLEWARE_CLASSES給定的順序申請中間件,而在應(yīng)答和異常階段,Djang
o使用相反的順序申請中間件,即Django把MIDDLEWARE_CLASSES當(dāng)作一種視圖方法的"包裝器":在請求時,它自頂向下申請這
個列表的中間件到視圖,而在應(yīng)答時它反序進行

中間件方法
既然我們知道了什么是中間件和怎樣安裝它,讓我們來看看中間件類可能定義的所有可得到的方法

初始化:__init__(self)
如果中間件類定義了一個構(gòu)造方法(即一個__init__方法),它應(yīng)該不使用參數(shù)(除了標(biāo)準(zhǔn)的slef)
出于性能考慮,中間件類在長時間運行的服務(wù)器過程中只初始化一次,這意味著你不能指望每次請求運行時調(diào)用__init__,
只有在服務(wù)器啟動時調(diào)用一次
中間件類可能也使用初始化時間來刪除它們本身而不是被安裝,如果初始化時觸發(fā)django.exceptions.MiddlewareNotUsed異
常,則Django將從中間件堆棧刪除該中間件,你可能使用這點來檢查中間件類依賴的一些軟件,或者服務(wù)器是否運行在調(diào)試
模式下,或者任何其它可能讓你想禁止中間件的類型的環(huán)境

請求預(yù)處理:process_request(self, request)
該方法在請求被接收和URL被解析來決定運行哪個視圖之前立即調(diào)用,它傳遞你可能想修改的HttpRequest對象
process_request()應(yīng)該返回None或者HttpResponse對象,如果它返回None,Django將繼續(xù)處理該請求,執(zhí)行任何其它的中間
件然后是合適的視圖
如果請求中間件返回HttpResponse對象,Django將不會再調(diào)用其它任何中間件(任何類型)或者合適的視圖,它將返回該應(yīng)答

視圖預(yù)處理:process_view(self, request, view, args, kwargs)
該方法在請求中間件運行后和URL被解析到一個視圖后和視圖實際上被調(diào)用之前被調(diào)用
傳遞給該視圖的參數(shù)為:
Argument           Explanation
request            HttpRequest對象
view               Django將會調(diào)用來樹立該請求的Python方法,它是實際上的方法對象本身,而不是方法名字符串
args               將被傳遞給視圖的位置參數(shù)列表,不包括request參數(shù)(它一直是視圖的第一個參數(shù))
kwargs             將被傳遞給視圖的關(guān)鍵字參數(shù)字典
像process_request()一樣,process_view()應(yīng)該返回None或者HttpResponse對象,如果它返回None,Django將繼續(xù)處理請求
執(zhí)行任何其它的視圖中間件然后是合適的視圖
如果視圖中間件返回HttpResponse對象,Django將不會再調(diào)用其它任何中間件或者合適的視圖,它將返回該應(yīng)答

應(yīng)答后處理:process_response(self, request, response)
該方法再視圖方法已經(jīng)調(diào)用和應(yīng)答生成后調(diào)用,這是中間件修改應(yīng)答輸出的地方,輸出壓縮(見下)是應(yīng)答中間件的一個顯然
的應(yīng)用
參數(shù)應(yīng)該非常自明了--request是請求對象,response是從視圖返回的應(yīng)答對象
不像請求和視圖中間件,它們可以返回None,process_response()必須返回一個HttpResponse對象,該應(yīng)答可以是傳遞給該
方法的原始應(yīng)答(可能被修改了)或者新的應(yīng)答

異常后處理:process_exception(self, request, exception)
該方法只在出錯并且視圖觸發(fā)不可捕獲的異常時調(diào)用,不包括Http404異常,你可以使用這個鉤子來發(fā)送錯誤通知,在一個日
志文件記錄信息,或者甚至嘗試自動恢復(fù)該錯誤
該方法的參數(shù)是我們一直處理的同樣的request對象和視圖方法觸發(fā)的真正的Exception對象exception
process_exception()可能返回一個作為應(yīng)答顯示給瀏覽器的HttpResponse或者返回None來繼續(xù)Django內(nèi)建的異常處理

例子
Django自帶一些中間件類--上面討論了--它們是很好的例子,閱讀它們的代碼應(yīng)該給你中間件的力量的好的感覺
你也可以在Django的wiki上找到一些社區(qū)貢獻的例子:
http://code.djangoproject.com/wiki/ContributedMiddleware

內(nèi)建的中間件
Django帶有一些內(nèi)建的中間件來處理常見的問題

認證支持中間件
中間件類:django.contrib.auth.middleware.AuthenticationMiddleware
運行認證支持,技術(shù)上,該中間件為每個進來的HttpRequest對象添加了表示當(dāng)前登錄的用戶的request.user屬性
參考第15章得到完整的細節(jié)

"Common"中間件
中間件類:django.middleware.common.CommonMiddleware
為完美主義者添加一些方便:
1,禁止訪問在DISALLOWED_USER_AGENTS設(shè)置中的user agents,該設(shè)置應(yīng)該是一個字符串列表
2,基于APPEND_SLASH和PREPEND_WWW設(shè)置執(zhí)行URL重定向,如果APPEND_SLASH為True,缺少結(jié)尾的斜線的URLs將被重定向到相
同的結(jié)尾有斜線的URL,除非路徑中最后的組件包含一個小數(shù)點,所以foo.com/bar被重定向到foo.com/bar/,但是foo.com/
bar/file.txt會無更改的傳遞
如果PREPEND_WWW為True,缺少開頭的"www."的URLs將被重定向到相同的有開頭的"www."的URL
這些選項都意味著規(guī)范化URLs,哲學(xué)是每個URL應(yīng)該應(yīng)該存在于一個并且只有一個地方,技術(shù)上URL foo.com/bar和foo.com/
bar/不同--搜索引擎索引器將把它們視為不同的URLs,所以規(guī)范化URLs是最佳實踐
3,基于USE_ETAGS設(shè)置處理ETags,如果USE_ETAGS設(shè)置為True,Django將通過MD5-哈希頁面內(nèi)容為每個請求計算Etag,并且
如果合適的話它將注意發(fā)送未修改的應(yīng)答

壓縮中間件
中間件類:django.middleware.gzip.GZipMiddleware
如果被激活,該中間件將為理解gzip壓縮的瀏覽器(所有的現(xiàn)代瀏覽器)自動壓縮內(nèi)容
這可以以處理時間為代價很大的減少web服務(wù)器消耗的帶寬數(shù)量,我們通常選擇速度而不是帶寬,但是如果你想使用相反的一
邊,只需激活該中間件

有條件的GET中間件
中間件類:django.middleware.http.ConditionalGetMiddleware
如果被激活,它提供有條件的GET操作支持,如果應(yīng)答有一個ETag或者Last-Modified頭部,并請求有If-None-Match或者If-
Modified-Since,應(yīng)答將被304("未修改")應(yīng)答替換
它也為所有請求刪除任何應(yīng)答到HEAD請求的內(nèi)容并設(shè)置Date和Content-Length應(yīng)答頭部

倒轉(zhuǎn)代理支持(X-Forwarede-For中間件)
中間件類:django.middleware.http.SetRemoteAddrFromForwaredFor
則是我們上面看到的例子,它基于request.META['HTTP_X_FORWARDED_FOR']設(shè)置request.META['REMOTE_ADDR'],如果前者
設(shè)置了的話,這當(dāng)你位于將每個請求的REMOTE_ADDR設(shè)置為127.0.0.1的倒轉(zhuǎn)代理后面時很有用
危險,Will Robinson!
它不驗證HTTP_X_FORWARDED_FOR
如果你沒有在自動設(shè)置HTTP_X_FORWARDED_FOR的倒轉(zhuǎn)代理后面,則不要使用該中間件,任何人都可以欺騙HTTP_X_FORWARDED_
FOR的值,由于它基于HTTP_X_FORWARDED_FOR設(shè)置REMOTE_ADDR,這意味著任何人可以偽造他們的IP地址
只有當(dāng)你可以絕對信任HTTP_X_FORWARDED_FOR的值時使用該中間件

Session支持中間件
中間件類:django.contrib.sessions.middleware.SessionMiddleware
允許session支持,參考第15章的細節(jié)

站點寬度緩存中間件
中間件類:django.middleware.cache.CacheMiddleware
如果被激活,每個Django驅(qū)動的頁面將被緩存,這在第14章詳細討論了

事務(wù)中間件
中間件類:django.middleware.transaction.TransactionMiddleware
在請求/應(yīng)答階段綁定數(shù)據(jù)庫COMMIT或者ROLLBACK,如果視圖方法成功運行,則COMMIT完成,如果它以異常失敗,則ROLLBACK
完成
在堆棧中該中間件的順序很重要:運行在它外面的中間件模塊以Django默認行為commit-on-save運行,運行在它里面(在堆棧
中它后面)的中間件模塊將和視圖方法處于同一事務(wù)控制
參考XXX來得到更多關(guān)于數(shù)據(jù)庫事務(wù)的信息

"X-View"中間件
中間件類:django.middleware.doc.XViewMiddleware
對來自INTERNAL_IPS設(shè)置中定義的IP地址的HEAD請求發(fā)送自定義X-View HTTP頭部,它被Django的自動文檔系統(tǒng)使用
安徽新華電腦學(xué)校專業(yè)職業(yè)規(guī)劃師為你提供更多幫助【在線咨詢
亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区
久久久噜噜噜久久久| 国模精品一区二区三区| 欧美精品福利在线| 国产精品一区二区久久精品| 久久在精品线影院精品国产| 热99精品只有里视频精品| 国产成人精品久久二区二区91| 日韩免费精品视频| 国产精品国产福利国产秒拍| 国产免费一区二区三区视频| 亚洲不卡中文字幕| 日韩在线视频线视频免费网站| 激情综合在线观看| 欧美激情综合色| 日韩中文字幕在线精品| 久久久久久网站| 久久精品国产69国产精品亚洲| 国产三级中文字幕| 日本视频一区在线观看| 国产精品久久久久9999爆乳| 国产久一道中文一区| 国产精品一区在线免费观看| 91av免费观看91av精品在线| 国内精品久久久久久影视8 | 欧美精品手机在线| 亚洲午夜久久久影院伊人| 色偷偷噜噜噜亚洲男人| 久久久999国产精品| 久久亚洲精品一区| 亚洲欧美国产一区二区| 国产精品免费小视频| 91精品国产高清自在线看超| 久久精品网站视频| 国产精品欧美日韩| 国产99久久精品一区二区永久免费| 亚洲午夜精品一区二区| 日本精品免费视频| 亚洲精品日韩av| 日韩精品在在线一区二区中文| 美女被啪啪一区二区| 91久久精品国产| 国产日韩在线一区| 91精品国产亚洲| 国产精品久久电影观看| 亚洲不卡中文字幕无码| 国内精品**久久毛片app| 国产经典一区二区三区| 国产美女直播视频一区| 国产精品99久久久久久人| 国产精品中文字幕在线观看| 久久96国产精品久久99软件| 欧美人与性动交a欧美精品| 日韩精品一区二区在线视频| 99视频国产精品免费观看| 成人av网站观看| 国产精品丝袜高跟| 日本在线视频www| 成人久久久久久久久| 成人综合国产精品| 久久精品人人爽| 日韩中文字幕在线不卡| 日韩av电影在线播放| 国产日韩欧美综合| 色偷偷噜噜噜亚洲男人| 亚洲www在线观看| 国产女教师bbwbbwbbw| 国产精品免费一区二区三区四区| 日本在线视频www| 91久久精品国产91久久| 欧美激情欧美激情在线五月| 国内精品久久久| 久久久精品一区二区三区| 欧美一区二区三区四区夜夜大片| 国产精选一区二区| 精品国产aⅴ麻豆| 欧美激情精品久久久久| 欧美精品久久| 国产乱淫av片杨贵妃| 久久精品国产91精品亚洲| 日韩精品第1页| 国产成人精品av在线| 无码免费一区二区三区免费播放 | 久久综合久久久久| 中文字幕一区二区中文字幕| 国产免费一区二区三区在线观看| 国产精品精品视频| 国自在线精品视频| 国产精品免费久久久久久| 欧美在线欧美在线| 按摩亚洲人久久| 国产精品人人妻人人爽人人牛| 日韩wuma| 日韩中文在线不卡| 欧美日韩一区二区三区在线观看免 | 久久精品99久久| 视频一区二区三区免费观看| 久久免费精品日本久久中文字幕| 久久久久久久午夜| 午夜精品区一区二区三| 成人av免费电影| 中文字幕一区综合| 久久久亚洲成人| 青青草国产免费| 国产精品日韩欧美综合| 国产九色91| 日本一区视频在线播放| 日韩中文理论片| 欧美亚洲在线观看| 国产精品影院在线观看| 亚洲午夜精品一区二区| 国产国语刺激对白av不卡| 日本一区二区三区四区在线观看| 国产成人精品a视频一区www| 欧美在线观看一区二区三区| 久久精品国产亚洲精品| 国产一区欧美二区三区| 国产精品88a∨| 日韩精品一区二区三区色偷偷| 久久精品国产91精品亚洲| 国产原创精品| 视频一区在线免费观看| 国产精品老女人精品视频| 福利精品视频| 奇米四色中文综合久久| 久久亚洲精品视频| 91精品国产精品| 免费看污污视频| 亚洲精品成人三区| 久久精品影视伊人网| 国产伦精品一区二区三区免| 欧美一级片在线播放| 国产精品网址在线| 91九色视频在线观看| 欧美日韩免费精品| 亚洲综合精品伊人久久| 久久久久久网站| 国产精品一区二区女厕厕| 青青草影院在线观看| 综合操久久久| 国产chinese精品一区二区| 国产在线久久久| 日本一区二区三区四区视频| 精品麻豆av| 日韩在线激情视频| 国产精品午夜一区二区欲梦| 日韩黄色片在线| 亚洲在线第一页| 国产精品狠色婷| 久久久久久国产精品免费免费 | 美女主播视频一区| 日本视频一区在线观看| 久久99青青精品免费观看| 日韩在线视频线视频免费网站| chinese少妇国语对白| 免费一级特黄毛片| 日韩极品视频在线观看| 亚洲v欧美v另类v综合v日韩v| 久久伊人91精品综合网站| 国产传媒欧美日韩| www.亚洲天堂网| 国产一区二区高清视频| 欧美午夜精品久久久久免费视| 亚洲国产一区二区三区在线 | 国产一级大片免费看| 人妻熟女一二三区夜夜爱| 亚洲一区二区中文字幕| 精品国产一区二区三区久久久久久 | 国产一区二区三区黄| 欧美另类一区| 日本精品视频一区| 手机看片日韩国产| 亚洲欧洲日本国产| 欧美日韩国产二区| 精品国产成人av在线免| 国产精品美女www| 久久精品视频亚洲| 国产成人女人毛片视频在线| 久久久久久久一区二区| 国产xxxx振车| 国产精品99久久99久久久二8| 北条麻妃在线一区| 成人在线观看a| av资源站久久亚洲| www.中文字幕在线| 99在线首页视频| 99久久激情视频| 91久久久一线二线三线品牌| 97久久精品在线| 97精品视频在线| 97精品免费视频| 久久久久久草| 久久久久久网站| 久久精品国产精品| 久久精品国产成人精品| 久久精品国产一区二区三区| 日韩中文字幕亚洲| 国产精品第三页| 在线视频一区观看| 色综合电影网| 青青草一区二区|