![](/img/trans.png)
[英]The SECRET_KEY setting must not be empty || Available at Settings.py
[英]Django Settings.py - SECRET_KEY - KeyError
目前有一個Django項目在 Python 3.6.9 上運行,使用Gunicorn和Nginx托管在Digital ocean上。
我試圖將我的SECRET_KEY
和其他密碼切換到環境變量,而不是將它們作為settings.py
中的字符串。
這樣做時我遇到了以下錯誤並且 Gunicorn 關閉了。
Dec 10 15:22:20: File "/home/user/projectdir/project/project/settings.py", line 23, in <module>
Dec 10 15:22:20 droplet_name gunicorn: SECRET_KEY = os.environ['SECRET_KEY']
Dec 10 15:22:20 droplet_name gunicorn: File "/home/user/projectdir/myenv/lib/python3.6/os.py", line 669, in __getitem__
Dec 10 15:22:20 droplet_name gunicorn: raise KeyError(key) from None
Dec 10 15:22:20 droplet_name gunicorn: KeyError: 'SECRET_KEY'
Dec 10 15:22:20 droplet_name gunicorn: [2019-12-10 15:22:20 +0000] [20022] [INFO] Worker exiting (pid: 20022)
我之前通過執行正確導出了SECRET_KEY
export SECRET_KEY='my_key'
這也是我的settings.py
的樣子:
import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
SECRET_KEY = os.environ['SECRET_KEY']
DEBUG = False
ALLOWED_HOSTS = ["my_ip"]
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'home',
]
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 = 'project_name.urls'
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [],
'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 = 'project_name.wsgi.application'
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'NAME': 'projectnamedb',
'USER': 'myuser',
'PASSWORD': 'mypass',
'HOST': 'localhost',
'PORT': '',
}
}
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',
},
]
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True
STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
MEDIA_URL = "/media/"
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
LOGIN_URL = '/home/user_login'
我已經閱讀了至少十幾個類似的帖子,但仍然無法解決問題。 如果可能,我想在不加載新庫的情況下使用os.environ
。
更新:我使用以下代碼將test_one.py
文檔放在與 settings.py 相同的目錄中。 運行時,它輸出SECRET_KEY
並返回一個字符串作為預期的類型。 仍然無法在settings.py
文件上獲得相同的結果。
import os
print(os.environ['SECRET_KEY'])
print(type(os.environ['SECRET_KEY']))
SECRET_KEY = os.environ['SECRET_KEY']
print(type(SECRET_KEY))
我另外將環境變量的值轉換為字符串。 然后它對我有用。 我的猜測是,根據您的私鑰包含哪些特殊字符,讀取環境變量可能會出現問題:
SECRET_KEY = str(os.environ.get('SECRET_KEY'))
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.