当 DEBUG = False(产品)时,Django 管理错误(总是需要登录几次)

Posted

技术标签:

【中文标题】当 DEBUG = False(产品)时,Django 管理错误(总是需要登录几次)【英文标题】:Django Admin Error (Always require login couple of time) when DEBUG = False (Productions) 【发布时间】:2019-09-29 23:18:27 【问题描述】:

我刚刚在 Google App Engine 中部署了 Django 2.2。

除了这个,一切都很好。 管理页面需要登录几次,直到我终于可以进入仪表板。 当我单击 Post 模型创建新帖子时也会发生这种情况,我需要再次登录。 我不知道为什么,但是当DEBUG = False 时会发生这种情况。

我看了一下这个question 和his answer,但调试时可能有点不同。

有没有人和我一样的问题?

这是我的settings.py 文件:

DEBUG = False
# SECURITY WARNING: don't run with debug turned on in production!


BASE_URL = "https://example.com"

ALLOWED_HOSTS = ['*']

# ALLOWED_HOSTS = [
#     'www.notnoob.com',
#     'notnoob.com'
# ]


# SESSION_COOKIE_NAME
# SESSION_COOKIE_DOMAIN = None
SECURE_SSL_REDIRECT = True
SESSION_COOKIE_SECURE = True
CSRF_COOKIE_SECURE = True
SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', 'https')

# Application definition
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'django.contrib.sites',
    'django.contrib.sitemaps',
    'home',
    'blog',                                                                 
    'contact',
    'ckeditor',
    'ckeditor_uploader',
    'taggit',
    'meta',
    'django_filters',

]

...
...

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

ROOT_URLCONF = 'dj.urls'

TEMPLATES = [
    
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'dj/templates')],
        'APP_DIRS': True,
        'OPTIONS': 
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',

            ],
        ,
    ,
]

WSGI_APPLICATION = 'dj.wsgi.application'

.....
.....

DATABASES = 
    'default': 
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    


DATABASES['default']['HOST'] = 'cloudsql/djangoblogdb'
if os.getenv('GAE_INSTANCE'):
    pass
else:
    DATABASES['default']['HOST'] = 'localhost'


# Password validation
# https://docs.djangoproject.com/en/2.2/ref/settings/#auth-password-validators

AUTH_PASSWORD_VALIDATORS = [
    
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    ,
    
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    ,
    
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    ,
    
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    ,
]

不知道为什么,但是当DEBUG = True,一切顺利。

我的admin.py

from django.contrib import admin
from blog.models import Post, MetaModel

admin.site.site_header = "Welcome To iColdPlayer"
admin.site.site_title = "iColdPlayer Administrator"
admin.site.site_index = "iColdPlayer"

# site = admin.AdminSite(name="iColdPlayer")

# class PostAdmin(admin.ModelAdmin):
#     pass
#
# class MetaModelAdmin(admin.ModelAdmin):
#     pass

admin.site.register(Post)
admin.site.register(MetaModel)

编辑:我正在使用灵活的环境

【问题讨论】:

【参考方案1】:

问题是您将数据存储在 SQLITE3 中,并且您可能运行了多个 GAE。

所以你在实例 1 上登录,但被重定向到实例 2(无状态.....)

你猜怎么着,在 2 日,你还没有登录,所以你必须重新登录。

要解决此问题,请将您的 app.yml 更改为将最大实例设置为 1 或使用 GAE 外部的 mysql 来存储您的会话....

如果解决了请告诉我

【讨论】:

不知道你的意思是不是一个存储桶。因为我只有一个实例。 发送您正在运行的实例的屏幕截图(在 Google 仪表板上),请发送您的 app.yml 截图如下:-instance running-app.yaml-Storage Bucket 在您的应用程序 yaml 上,将最大实例数定义为 1... 您是否使用了 postgree? b/c 你的设置说 SQLITE 好吧,我认为这对不同的数据库是有意义的。因为我认为就像在 heroku 上一样,我们可以在部署时使用不同的数据库。已经在beta_settings: instances: 1 下更改了我的settings.py,但还没有更改为db。我还是很好奇……

以上是关于当 DEBUG = False(产品)时,Django 管理错误(总是需要登录几次)的主要内容,如果未能解决你的问题,请参考以下文章

当 debug=False 时可能导致 Django 错误,而当 debug=True 时不存在

Django Elasticbeanstalk:当 Debug = False 时无法访问静态文件

当 DEBUG=False 时,我的 Django 管理面板给出服务器错误(500)

当 Debug=False 时 Django Heroku 不提供静态文件

为啥当 Debug 设置为 False 时,Django 会为静态媒体生成 HTTP 500 错误?

当 debug=false 时 Django 媒体文件不起作用