关于django框架的一些配置(settings.py)
- M 代表模型(Model): 负责业务对象和数据库的关系映射(ORM)。
- T 代表模板 (Template):负责如何把页面展示给用户(html)。
- V 代表视图(View): 负责业务逻辑,并在适当时候调用Model和Template。
除了以上三层之外,还需要一个URL分发器,它的作用是将一个个URL的页面请求分发给不同的View处理,View再调用相应的Model和Template,MTV的响应模式如下所示:
①url配置
# 是否开启URL访问地址后面不为‘/’跳转至带有‘/’的路径的配置项
访问 http://www.example.com/blog 时,默认将网址自动转换为 http://www.example/com/blog/ 。
APPEND_SLASH=True(settings.py中默认没有这个,按需求配置,没有配置的时候默认是True)
如果在settings.py中设置了 APPEND_SLASH=False,此时再请求 http://www.example.com/blog 时就会提示找不到页面。
②view配置 # Application definition
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles', # 上面的这些配置是django框架自带的
'app01.apps.App01Config',
'app02.apps.App02Config', # 两个app应用,项目中添加一个应用都要在这里改成文件夹的名字,直接写“app01”也可以。
# 可以看到“app01”文件夹下apps.py 就知道为什么这个文件配置是这样了。
]
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware', # 这个是POST请求认证安全机制,如果django框架没有拿到html页面中CSRF值是提交不了的,一种伪保护
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
③templates模板
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')], # 配置放html文件的路径,url配置中的路径都会自动找到改路径下的html文件
'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',
],
},
},
]
# 静态文件配置 比如css,js,图片视频等。
STATIC_URL = '/static/' #别名,在urls.py中加多一个name=‘别名’参数,便于维护更新迭代
STATICFILES_DIRS = [ os.path.join(BASE_DIR,'jingtaiwenjian'), #注意别忘了写逗号,第二个参数就是项目中你存放静态文件的文件夹名称 ]
④models模型
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC' # 设置时区地区 如'Asia/Shanghai'
USE_I18N = True
USE_L10N = True
APPEND_SLASH = FALSE # 不会再url后自动加“/”
USE_TZ = True # 在操作数据库的时候,涉及时间日期的要注意,这个True表示让数据库考虑时区的问题,False则不考虑时区问题,会将本地时间写入
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 要连接其他数据库 改动‘mysql’即可
'NAME':'bms', # 要连接的数据库,连接前需要创建好
'USER':'root', # 连接数据库的用户名
'PASSWORD':'', # 连接数据库的密码
'HOST':'127.0.0.1', # 连接主机,默认本机
'PORT':3306 # 端口 默认3306
'OPTIONS': {
"init_command": "SET default_storage_engine='INNODB'",
# 'init_command': "SET sql_mode='STRICT_TRANS_TABLES'",
}
"ATOMIC_REQUESTS": True, #全局开启事务,绑定的是http请求响应整个过程,不建议配置,不是所有sql语句都需要用到事务的
'other':{
'ENGINE': 'django.db.backends.mysql',
......
} #还可以配置其他数据库
}
DATABASES['default']['OPTIONS']['init_command'] = "SET sql_mode='STRICT_TRANS_TABLES'" # 设置成严格模式,在项目中若出现关于Mode的警告,可以在django项目这里设置,或者去数据库设置成严格模式。
#下面的代码放进settings.py中 可以看到原生sql语句执行
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console':{
'level':'DEBUG',
'class':'logging.StreamHandler',
},
},
'loggers': {
'django.db.backends': {
'handlers': ['console'],
'propagate': True,
'level':'DEBUG',
},
}
}