認證支持中間件
中間件類: django.contrib.auth.middleware.AuthenticationMiddleware . django.contrib.auth.middleware.AuthenticationMiddleware .
這個中間件激活認證支持功能. 它在每個傳入的 HttpRequest 對象中添加代表當前登錄用戶的 request.user 屬性。 It adds the request.user attribute, representing the currently logged-in user, to every incoming HttpRequest object.
通用中間件
Middleware class: django.middleware.common.CommonMiddleware .
這個中間件為完美主義者提供了一些便利:
禁止 ``DISALLOWED_USER_AGENTS`` 列表中所設置的user agent訪問 :一旦提供,這一列表應當由已編譯的正則表達式對象組成,這些對象用于匹配傳入的request請求頭中的user-agent域。 下面這個例子來自某個配置文件片段:
import reDISALLOWED_USER_AGENTS = ( re.compile(r'^OmniExplorer_Bot'), re.compile(r'^Googlebot'))
壓縮中間件
中間件類 django.middleware.gzip.GZipMiddleware .
這個中間件自動為能處理gzip壓縮(包括所有的現(xiàn)代瀏覽器)的瀏覽器自動壓縮返回]內容。 這將極大地減少Web服務器所耗用的帶寬。 代價是壓縮頁面需要一些額外的處理時間。
相對于帶寬,人們一般更青睞于速度,但是如果你的情形正好相反,盡可啟用這個中間件。
條件化的GET中間件
Middleware class: django.middleware.http.ConditionalGetMiddleware .
這個中間件對條件化 GET 操作提供支持。 如果response頭中包括 Last-Modified 或 ETag 域,并且request頭中包含 If-None-Match 或 If-Modified-Since 域,且兩者一致,則該response將被response 304(Not modified)取代。 對 ETag 的支持依賴于 USE_ETAGS 配置及事先在response頭中設置 ETag 域。稍前所討論的通用中間件可用于設置response中的 ETag 域。 As discussed above, the ETag header is set by the Common middleware.
此外,它也將刪除處理 HEAD request時所生成的response中的任何內容,并在所有request的response頭中設置 Date 和 Content-Length 域。
反向代理支持 (X-Forwarded-For中間件)
Middleware class: django.middleware.http.SetRemoteAddrFromForwardedFor .
這是我們在 什么是中間件 這一節(jié)中所舉的例子。 在 request.META['HTTP_X_FORWARDED_FOR'] 存在的前提下,它根據(jù)其值來設置 request.META['REMOTE_ADDR'] 。在站點位于某個反向代理之后的、每個request的 REMOTE_ADDR 都被指向 127.0.0.1 的情形下,這一功能將非常有用。 It sets request.META['REMOTE_ADDR'] based on request.META['HTTP_X_FORWARDED_FOR'] , if the latter is set. This is useful if you're sitting behind a reverse proxy that causes each request's REMOTE_ADDR to be set to 127.0.0.1 .
紅色警告!
這個middleware并 不 驗證 HTTP_X_FORWARDED_FOR 的合法性。
如果站點并不位于自動設置 HTTP_X_FORWARDED_FOR 的反向代理之后,請不要使用這個中間件。 否則,因為任何人都能夠偽造 HTTP_X_FORWARDED_FOR 值,而 REMOTE_ADDR 又是依據(jù) HTTP_X_FORWARDED_FOR 來設置,這就意味著任何人都能夠偽造IP地址。
只有當能夠絕對信任 HTTP_X_FORWARDED_FOR 值得時候才能夠使用這個中間件。
會話支持中間件
Middleware class: django.contrib.sessions.middleware.SessionMiddleware .
這個中間件激活會話支持功能.
Middleware classes: django.middleware.cache.UpdateCacheMiddleware and django.middleware.cache.FetchFromCacheMiddleware .
這些中間件互相配合以緩存每個基于Django的頁面。
事務處理中間件
Middleware class: django.middleware.transaction.TransactionMiddleware .
這個中間件將數(shù)據(jù)庫的 COMMIT 或 ROLLBACK 綁定到request/response處理階段。 如果view函數(shù)成功執(zhí)行,則發(fā)出 COMMIT 指令。 如果view函數(shù)拋出異常,則發(fā)出 ROLLBACK 指令。
這個中間件在棧中的順序非常重要。 其外層的中間件模塊運行在Django缺省的 保存-提交 行為模式下。 而其內層中間件(在棧中的其后位置出現(xiàn))將置于與view函數(shù)一致的事務機制的控制下。
新聞熱點
疑難解答
圖片精選