# django的配置文件中的配置项是什么意思?
import os # 导入模块# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
# 用一个变量来保存一个路径 __file__ :当前这份文件的路径
# 在开发中,路径不要写死,不建议使用绝对路径,避免因为路径变动了造成的bug# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'mu4#59%=%f*e8x6d9+p26f#6ch&5)&+)mte7+wq)717uxu56ap'
# 随机字符串,django 运行必须需要这个,session、加密等情况会使用# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True # 调试模式
# 设置为Ture 则表示开启调试模式 就会将遇到的错误以及错误信息展示出来
# 在开发的时候,应该开启 方便我们进行排错
# 设置为False 则表示关闭调试模式 不会展示错误信息
# 在生产环境下,不能开启调试模式 避免出错,错误信息展示出来了,容易导致引发安全问题ALLOWED_HOSTS = []
# 允许访问的IP
# 当我们将DEBUG 设置为False的时候,只有这个列表里面的IP才能访问django项目
# 一般我们会将服务器的IP放在里面
# 如果是 * 就表示允许所有的IP 进行访问# Application definition# 是个列表,列表的每一项是 安装了的APP 默认安装的APP
# sys.path 的列表 默认能找到
INSTALLED_APPS = ['django.contrib.admin', # 自带的admin管理后台'django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions', # 使用Session'django.contrib.messages','django.contrib.staticfiles', # 静态文件
]# 中间件 按照从上往下的顺序 依次执行
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',
]# 告诉django路由文件的位置
ROOT_URLCONF = 'blog.urls'# 模板相关的设置
TEMPLATES = [{# 使用的模板引擎是什么'BACKEND': 'django.template.backends.django.DjangoTemplates',# 是个列表 django会从这个列表中的每一项依次去找对应的模板文件'DIRS': [],# 默认为True 表示会从app里面去找 一个叫做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 = 'blog.wsgi.application'# 数据库相关配置,当使用mysql数据库时需要更改此设置
DATABASES = {'default': {'ENGINE': 'django.db.backends.sqlite3','NAME': os.path.join(BASE_DIR, '../../db.sqlite3'),}
}# 权限和密码认证相关设置
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 = 'zh-hans'
# LANGUAGE_CODE = 'en-us'# 时区的设置 默认是UTC世界标准时间
# 想改成东八区
TIME_ZONE = 'Asia/Shanghai'
# TIME_ZONE = 'UTC'USE_I18N = TrueUSE_L10N = True# 设置是否采用时区
# 如果是True 会保留时区的设置 在数据库保存的时间是带时区的
# 设置为False 就不会保存时区 在数据库就是本地时间
USE_TZ = False
# USE_TZ = True在项目上线以后,要关闭调试模式,避免引起安全攻击,但是这样我们就看不到一些信息了,在实际中,我们的项目上线后可能还会遇到问题的,所以我们应该要将这些问题记录下来才对,并且应该记录一些用户的请求记录记录下来,方便后续运营人员做分析,运维人员做问题分析等等,所以要求我们将一些信息记录在指定的文件中。
在blog/blog/下创建一个文件夹:logs
在setting/dev.py文件中添加如下代码
# 用django记录日志
LOGGING = {'version': 1, # 日志版本'disable_existing_loggers': False, # 是否禁用已经存在的日志器'formatters': { # 日志信息显示的格式'verbose': { # 复杂的信息'format': '%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s'},'simple': {'format': '%(levelname)s %(module)s %(lineno)d %(message)s'},},'filters': { # 对日志进行过滤'require_debug_true': { # django在debug模式下才输出日志'()': 'django.utils.log.RequireDebugTrue',},},'handlers': { # 日志处理方法'console': { # 向终端中输出日志'level': 'INFO','filters': ['require_debug_true'],'class': 'logging.StreamHandler','formatter': 'simple'},'file': { # 向文件中输出日志'level': 'INFO','class': 'logging.handlers.RotatingFileHandler','filename': os.path.join(BASE_DIR, 'logs/debug.log'), # 日志文件的位置'maxBytes': 300 * 1024 * 1024, # 300M'backupCount': 10, # 10份文件'formatter': 'verbose'},},'loggers': { # 日志器'django': { # 定义了一个名为django的日志器'handlers': ['console', 'file'], # 可以同时向终端与文件中输出日志'propagate': True, # 是否继续传递日志信息'level': 'INFO', # 日志器接收的最低日志级别},}
}这样,项目执行的日志记录信息都会保存在logs文件夹下
在blog/blog里面创建一个叫做static的文件夹,用来存放css等静态文件
在dev.py文件中添加如下代码:
# 配置静态文件的文件夹位置
STATICFILES_DIRS = [os.path.join(BASE_DIR,'static')
]在blog/blog里面创建一个叫做templates的文件夹
在dev.py文件中进行如设置:
# 模板相关的设置
TEMPLATES = [{'BACKEND': 'django.template.backends.django.DjangoTemplates','DIRS': [os.path.join(BASE_DIR,'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',],},},
]可以鼠标选中templates,右键选择make Directory as--->Templates Folder,这样就可以在其他程序中输入templates文件夹里的文件时拥有代码提示了。
为了方便管理,(例如以后可能有多个版本等等问题),在blog\blog里面创建一个apps的软件包,以后所有的app都放在这个包里面,方便管理。
# 创建user的app的命令:python manage.py startapp user
# 这条命令在哪里运行的,就会在当前的路径下创建这个app
# 我们需要先进入虚拟环境,再cd到blog/blog/apps文件夹下,执行以下命令创建user
python ../../manage.py startapp user
# 因为要依赖manage.py文件创建app,所以要指定manage.py的位置,所以要使用“../../manage.py”创建了app后,要在配置文件中告诉Django
在dev.py文件中进行如下设置:
import sys # 新增代码
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
sys.path.append(os.path.join(BASE_DIR,'apps')) # 新增代码 追加导包路径
INSTALLED_APPS = [...'user', #在该列表的最后添加新增加的app名称
]在blog/urls.py文件中进行设置
from django.contrib import admin
from django.urls import path,includeurlpatterns = [path('admin/', admin.site.urls),# 进行路由分发path('user',include('user.urls')),
]在user文件夹中创建urls.py文件,进行路由设置:
from django.urls import pathapp_name = 'user'
urlpatterns = []blogblogsettings- dev.py (就是以前的Settings.py 作为开发环境的配置)- prod.py (作为以后上线的环境配置)apps (新增的包 用来存放app)user 的应用logs (新增的文件夹 用来存在日志信息)templates (新增的文件夹 用来存在模板文件)static (新增的文件夹 用来存在静态资源)-wsgi.py (部署文件 做了修改)- manage.py # 项目启动文件 (做了修改)