2011-05-31 06:27:47 +08:00
|
|
|
"""
|
|
|
|
Clickjacking Protection Middleware.
|
|
|
|
|
|
|
|
This module provides a middleware that implements protection against a
|
|
|
|
malicious site loading resources from your site in a hidden frame.
|
|
|
|
"""
|
|
|
|
|
|
|
|
from django.conf import settings
|
2015-11-07 23:12:37 +08:00
|
|
|
from django.utils.deprecation import MiddlewareMixin
|
2011-05-31 06:27:47 +08:00
|
|
|
|
2013-11-03 04:12:09 +08:00
|
|
|
|
2015-11-07 23:12:37 +08:00
|
|
|
class XFrameOptionsMiddleware(MiddlewareMixin):
|
2011-05-31 06:27:47 +08:00
|
|
|
"""
|
2017-01-25 04:37:33 +08:00
|
|
|
Set the X-Frame-Options HTTP header in HTTP responses.
|
2011-05-31 06:27:47 +08:00
|
|
|
|
2017-01-25 04:37:33 +08:00
|
|
|
Do not set the header if it's already set or if the response contains
|
2011-05-31 06:27:47 +08:00
|
|
|
a xframe_options_exempt value set to True.
|
|
|
|
|
2017-01-25 04:37:33 +08:00
|
|
|
By default, set the X-Frame-Options header to 'SAMEORIGIN', meaning the
|
2011-05-31 06:27:47 +08:00
|
|
|
response can only be loaded on a frame within the same site. To prevent the
|
|
|
|
response from being loaded in a frame in any site, set X_FRAME_OPTIONS in
|
|
|
|
your project's Django settings to 'DENY'.
|
|
|
|
"""
|
|
|
|
def process_response(self, request, response):
|
|
|
|
# Don't set it if it's already in the response
|
2015-05-14 02:51:18 +08:00
|
|
|
if response.get('X-Frame-Options') is not None:
|
2011-05-31 06:27:47 +08:00
|
|
|
return response
|
|
|
|
|
|
|
|
# Don't set it if they used @xframe_options_exempt
|
|
|
|
if getattr(response, 'xframe_options_exempt', False):
|
|
|
|
return response
|
|
|
|
|
2020-07-14 19:32:24 +08:00
|
|
|
response.headers['X-Frame-Options'] = self.get_xframe_options_value(
|
|
|
|
request,
|
|
|
|
response,
|
|
|
|
)
|
2011-05-31 06:27:47 +08:00
|
|
|
return response
|
|
|
|
|
|
|
|
def get_xframe_options_value(self, request, response):
|
|
|
|
"""
|
2017-01-25 04:37:33 +08:00
|
|
|
Get the value to set for the X_FRAME_OPTIONS header. Use the value from
|
2019-09-07 15:52:10 +08:00
|
|
|
the X_FRAME_OPTIONS setting, or 'DENY' if not set.
|
2011-05-31 06:27:47 +08:00
|
|
|
|
|
|
|
This method can be overridden if needed, allowing it to vary based on
|
|
|
|
the request or response.
|
|
|
|
"""
|
2019-09-07 15:52:10 +08:00
|
|
|
return getattr(settings, 'X_FRAME_OPTIONS', 'DENY').upper()
|