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

首頁 > 編程 > Python > 正文

簡介Django中內置的一些中間件

2019-11-25 17:08:10
字體:
來源:轉載
供稿:網(wǎng)友

認證支持中間件

中間件類: 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'))
  •     請注意 import re ,因為 DISALLOWED_USER_AGENTS 要求其值為已編譯的正則表達式(也就是 re.compile() 的返回值)。
  •     依據(jù) ``APPEND_SLASH`` 和 ``PREPEND_WWW`` 的設置執(zhí)行URL重寫 :如果 APPEND_SLASH 為 True , 那些尾部沒有斜杠的URL將被重定向到添加了斜杠的相應URL,除非path的最末組成部分包含點號。 因此, foo.com/bar 會被重定向到 foo.com/bar/ , 但是 foo.com/bar/file.txt 將以不變形式通過。
  •     如果 PREPEND_WWW 為 True , 那些缺少先導www.的URLs將會被重定向到含有先導www.的相應URL上。 will be redirected to the same URL with a leading www..
  •     這兩個選項都是為了規(guī)范化URL。 其后的哲學是每個URL都應且只應當存在于一處。 技術上來說,URL example.com/bar 與 example.com/bar/ 及 www.example.com/bar/ 都互不相同。
  •     依據(jù) ``USE_ETAGS`` 的設置處理Etag : ETags 是HTTP級別上按條件緩存頁面的優(yōu)化機制。 如果 USE_ETAGS 為 True ,Django針對每個請求以MD5算法處理頁面內容,從而得到Etag, 在此基礎上,Django將在適當情形下處理并返回 Not Modified 回應(譯注:
  •     請注意,還有一個條件化的 GET 中間件, 處理Etags并干得更多,下面馬上就會提及。

壓縮中間件

中間件類 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ù)一致的事務機制的控制下。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 丽水市| 海盐县| 武平县| 运城市| 岚皋县| 沽源县| 文化| 咸丰县| 白朗县| 旬邑县| 麟游县| 怀远县| 八宿县| 左贡县| 治多县| 抚顺县| 恩施市| 鄂托克旗| 长岛县| 马山县| 化州市| 马关县| 龙南县| 宝山区| 定远县| 保定市| 综艺| 枝江市| 湖州市| 米泉市| 新乐市| 灵丘县| 黄梅县| 南丹县| 中超| 仁寿县| 汽车| 怀化市| 万盛区| 新疆| 志丹县|