1.加载数据库,数据库的配置不能写死在seting.py文件中,下面的方式是读取另外一个文件,配置数据库:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
config = ''
with open (os.path.join(base_dir, 'config/config.json' ), 'rt' ) as f:
config = json.load(f)
databases = {
'default' : {
'engine' : 'django.db.backends.mysql' ,
'name' : 'szrqgl' ,
'user' : config[ 'db_user' ],
'password' : config[ 'db_pwd' ],
'host' : config[ 'db_host' ],
'post' : config[ 'db_port' ]
}
}
|
上面的base_dir一般使用的都是默认值,即:
1
|
base_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
|
具体操作是创建一个config文件夹,该文件夹和你这个项目包同级,然后在其下面创建一个config.json文件,文件内容如下:
1
2
3
4
5
6
|
{
"db_user" : "root" ,
"db_pwd" : "123456" ,
"db_host" : "127.0.0.1" ,
"db_port" : "3306"
}
|
在上面的代码中,engine要说明一下,官方提供了针对不同数据库的的不同操作引擎,以下是经常用的几个:
sqlite数据库:'django.db.backends.sqlite3',
postgresql数据库:'django.db.backends.postgresql_psycopg2',
mysql数据库:'django.db.backends.mysql'
oracle数据库:'django.db.backends.oracle'
2.时区设置和字符集设置,一般用的都是下面三个:
设置保存到数据库时间类型是否为utc时间,如果不需要请设置为false,默认为true:use_tz = true
设置时区:time_zone = 'asia/shanghai'
设置语言:language_code = 'zh-hans'
设置字符集:default_charset = "utf-8"
3.设置国际化,根据个人需要进行设置:
国际化:use_i18n = true
相同内容被不同时区地区的用户访问时,是否以不同格式内容展示(例如时间,日期,数字):use_l10n = true
4.部署配置:
调试模式是否开启:debug = true
访问web服务的的ip配置:allowed_hosts = ['*']
部署的时候请修改debug和allowed_hosts的值,一般将其修改为false和指定ip,例如['127.0.0.1']
5.在setting.py中定义全局变量,该变量的变量名需要全部大写,否则会引用不到:
contextbool= false
6.app的安装配置,即installed_apps设置,我们新建的项目需要添加到该配置下,每个配置的意义以后说明:
django.contrib.admin —— 管理站点。
django.contrib.auth —— 认证系统。
django.contrib.contenttypes —— 用于内容类型的框架。
django.contrib.sessions —— 会话框架,session数据可以在数据库中的django_session表中查看。
django.contrib.messages —— 消息框架。
django.contrib.staticfiles —— 管理静态文件的框架。
例如:
1
2
3
4
5
6
7
8
9
|
installed_apps = [
'django.contrib.admin' ,
'django.contrib.auth' ,
'django.contrib.contenttypes' ,
'django.contrib.sessions' ,
'django.contrib.messages' ,
'django.contrib.staticfiles' ,
'demo1' ,
]
|
7.django的中间件配置,即middleware设置,所谓中间件就是从用户请求到用户请求结束期间所做的操作,即用户的请求会次从上到下依次执行middleware中的配置,然后服务器响应用户的时候会再次从下至上依次执行,和java的filter很相像:
1
2
3
4
5
6
7
8
9
|
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配置如上图,如果需要自己添加中间件配置的,也可自己添加,这里不再多说。
8.setting中的加密盐:
1
|
secret_key = 'i&&2$s&#%7npev^#uix==kis+h$4$ozscefiaw1c%p^+1c(l&6'
|
该配置是django的安全配置,防止攻击用的,该值是startproject时用系统的某个算法产生的.
9.静态文件目录配置(重中之重)
# 所有静态文件放置目录,在配置nginx的时候,nginx的静态资源要指向这里。
1
|
static_root = os.path.join(base_dir, 'static' ).replace( '\\', ' / ')
|
# 别名,这个别名指的是在html引用的名称
1
|
static_url = '/commonstatic/'
|
例如,下面的这个static实际上就是commonstatic,其在html里面显示如下:
1
2
3
|
{ % block styles % }
<link rel = "stylesheet" href = "{% static '/plugins/bootstrapvalidator/bootstrapvalidator.min.css' %}" rel = "external nofollow" >
{ % endblock % }
|
# 在django中指定静态文件的目录所在地
1
2
3
|
staticfiles_dirs = (
os.path.join(base_dir, 'commonstatic/' ).replace( '\\', ' / '),
)
|
一般情况下,上述的静态文件配置上面几乎可通用,绝少数情况下需要另配。
10.session会话配置(下面的配置会保存在数据库的django_session中):
1
2
3
4
5
6
7
8
9
|
session_engine = 'django.contrib.sessions.backends.db' # 引擎(默认)
session_cookie_name = "sessionid" # session的cookie保存在浏览器上时的key,即:sessionid=随机字符串(默认)
session_cookie_path = "/" # session的cookie保存的路径(默认)
session_cookie_domain = none # session的cookie保存的域名(默认)
session_cookie_secure = false # 是否https传输cookie(默认)
session_cookie_httponly = true # 是否session的cookie只支持http传输(默认)
session_cookie_age = 60 * 30 # session的cookie失效日期(30min)(默认)
session_expire_at_browser_close = true # 是否关闭浏览器使得session过期(默认)
session_save_every_request = true # 是否每次请求都保存session,默认修改之后才保存(默认)
|
setting配置文件的内容大致如上,具体每个配置的作用会在以后的文章中进行说明!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/u012605477/article/details/79466259