配置文件的介绍:dev.py(原来的setting.py文件)
# 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 = True
USE_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文件夹里的文件时拥有代码提示了。
创建apps
为了方便管理,(例如以后可能有多个版本等等问题),在blog\blog里面创建一个apps的软件包,以后所有的app都放在这个包里面,方便管理。
创建user的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,include
urlpatterns = [
path('admin/', admin.site.urls),
# 进行路由分发
path('user',include('user.urls')),
]
在user文件夹中创建urls.py文件,进行路由设置:
from django.contrib import admin
from django.urls import path,include
urlpatterns = [
path('admin/', admin.site.urls),
# 进行路由分发
path('user',include('user.urls')),
]
当前项目结构:
blog
blog
settings
- dev.py (就是以前的Settings.py 作为开发环境的配置)
- prod.py (作为以后上线的环境配置)
apps (新增的包 用来存放app)
user 的应用
logs (新增的文件夹 用来存在日志信息)
templates (新增的文件夹 用来存在模板文件)
static (新增的文件夹 用来存在静态资源)
-wsgi.py (部署文件 做了修改)
- manage.py # 项目启动文件 (做了修改)