Pythonanywhere 在标题中设置自定义定义
HTTP_X_REAL_IP
这是 pythonanywhere 接收请求的 IP 地址,这似乎最适合获取实际的客户端 IP。
您还可以使用 HTTP_X_FORWARDED_FOR,但理论上,如果传入请求在到达 pythonAnywhere 之前经过某种代理,则可能包含一组不同的 IP 地址。
为此,有两种选择。
首先,您可以将其添加到您的settings.py中
def custom_show_toolbar(request.META.get('HTTP_X_REAL_IP', None) in INTERNAL_IPS):
return True
# Show toolbar, if the IP returned from HTTP_X_REAL_IP IS listed as INTERNAL_IPS in settings
if request.is_ajax():
return False
# Show toolbar, if the request is not ajax
return bool(settings.DEBUG)
# show toolbar if debug is true
DEBUG_TOOLBAR_CONFIG = {
'SHOW_TOOLBAR_CALLBACK': custom_show_toolbar,
}
或者您可以修改 django-debug-toolbar 文件夹内的 middleware.py 文件,并更改以下代码:
def show_toolbar(request):
"""
Default function to determine whether to show the toolbar on a given page.
"""
if request.META.get('REMOTE_ADDR', None) not in settings.INTERNAL_IPS:
return False
if request.is_ajax():
return False
return bool(settings.DEBUG)
To:
def show_toolbar(request):
"""
Default function to determine whether to show the toolbar on a given page.
"""
if request.META.get('HTTP_X_REAL_IP', None) not in settings.INTERNAL_IPS:
return False
if request.is_ajax():
return False
return bool(settings.DEBUG)