Djangoで全ページキャッシュ禁止にする方法

WSGIサーバで動作させているDjangoのWebサイトで、全ページにHTTPヘッダーを付加し、キャッシュ禁止にする方法を紹介します。

キャッシュ禁止にしたい

WSGIサーバで動作させているDjango2.2のWebサイトにおいて、全ページにキャッシュ禁止のHTTPヘッダーを付加し、キャッシュ禁止にしたいときがありました。

下記を参考に、ミドルウェア(プラグインのようなもの)を追加し、対処します。

ミドルウェア (Middleware) | Django ドキュメント | Django

ミドルウェアの追加

モダンブラウザであれば、Cache-Controlヘッダーのみで十分なキャッシュ制御ができます。

Cache-Control
Cache-Control 一般ヘッダーフィールドは、リクエストとレスポンスの両方のキャッシュ規則を指定するために用います。キャッシュのディレクティブは単一方向であり、すなわちリクエストで指定されたディレクティブがレスポンスで同じディレクティブが指定されたものとはみなされません。

Cache-Controlヘッダーを追加するために、例えば /app/middleware/nocache.py にミドルウェアのPythonファイルを作成します。

from django.conf import settings
from django.utils.deprecation import MiddlewareMixin

class noCacheMiddleware(MiddlewareMixin):
    def process_response(self, request, response):
        response['Cache-Control'] = 'private, no-store, no-cache, must-revalidate, no-transform'
        return response
スポンサーリンク

setting.pyを編集

setting.pyMIDDLEWARE変数に今回追加したミドルウェアを追加します。

MIDDLEWARE = [
    'app.middleware.nocache.noCacheMiddleware',
]

動作の様子

Djangoレスポンスの例(developモードON)

Cache-Control

コメント