看我多久能学会Django(八):Django配置和静态文件

这一篇,我们看下setting.py文件。

配置文件

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__)))

这里用到了python中的一个变量 file 这个变量可以获取当前文件(包括这个代码的文件)的路径。
os.path.dirname(file)得到文件所在目录,再一个os.path.dirname()就是目录的上一级,BASE_DIR即为项目所在目录。我们在后面的与目录有关的变量都用它,这样使得移植性更强。

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

当DEBUG = True 时,如果出现 bug 便于我们看见问题所在,但是部署时最好不要让用户看见bug的详情。

ALLOWED_HOSTS = []

ALLOWED_HOSTS 允许我们设置哪些域名可以访问,即使在Apache或Nginx等中绑定了,这里不允许的话,也是不能访问的。

注意: 当 DEBUG=False 时,这个为必填项,如果不想输入,可以用 ALLOW_HOSTS = ['*'] 来允许所有的。

# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.10/howto/static-files/

STATIC_URL = '/static/'

static是静态文件所有目录,比如jquery.js, bootstrap.min.css 等文件。
一般来说我们只要把静态文件放在 APP 中的 static 目录下,部署时用 python manage.py collectstatic 就可以把静态文件收集到(复制到) STATIC_ROOT 目录,但是有时我们有一些共用的静态文件,这时候可以设置 STATICFILES_DIRS 另外弄一个文件夹,如下:

STATICFILES_DIRS = (
    os.path.join(BASE_DIR, "common_static"),
    '/var/www/static/',
)

这样我们就可以把静态文件放在 common_static 和 /var/www/static/中了,Django也能找到它们。

MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR,'media')

media文件夹用来存放用户上传的文件,与权限有关。

有时候有一些模板不是属于app的,比如 baidutongji.html, share.html等。

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [
            os.path.join(BASE_DIR,'templates').replace('\\', '/'),
            os.path.join(BASE_DIR,'templates2').replace('\\', '/'),
        ],
        'APP_DIRS': True,
]

这样 就可以把模板文件放在 templates 和 templates2 文件夹中了。

静态文件

静态文件是指网站中的js,css,图片,视频等文件

setting.py静态文件相关实例代码说明:

# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.10/howto/static-files/

STATIC_URL = '/static/'

#当运行 python manage.py collectstatic 的时候
#STATIC_ROOT文件夹是用来将所有STATICRTFILES_DIRS中所有文件夹中的文件,以及各app中static中的文件都复制过来
#把这些文件放在一起,是为了用apache等部署的时候方便使用
STATIC_ROOT = os.path.join(BASE_DIR,'collected_static') 

#其它存放静态文件的文件夹,可以用来存放项目中共用的静态文件,里面不能包含STATIC_ROOT
#如果不想使用STATICFILES_DIRS 可以不用,都放在app里的static中也可以
STATICFILES_DIRS=(
    os.path.join(BASE_DIR,"common_static"),
     '/path/to/others/static/',  # 用不到的时候可以不写这一行
)

# 这个是默认设置,Django 默认会在 STATICFILES_DIRS中的文件夹 和 各app下的static文件夹中找文件
# 注意有先后顺序,找到了就不再继续找了
STATICFILES_FINDERS = (
    "django.contrib.staticfiles.finders.FileSystemFinder",
    "django.contrib.staticfiles.finders.AppDirectoriesFinder"
)

静态文件放在对应的app下的static文件夹中或者STATICFILES_DIRS中的文件夹中。

当DEBUG=True时,Django 就能自动找到放在里面的静态文件。(Django 通过 STATICFILES_FINDERS 中的“查找器”,找到符合的就停下来,寻找的过程 类似于 Python 中使用 import xxx 时,找 xxx 这个包的过程)。

以自学堂的例子为栗子:

dj18static
├── blog
│   ├── __init__.py
│   ├── admin.py
│   ├── migrations
│   │   └── __init__.py
│   ├── models.py
│   ├── static # 应用 blog 下的 static, 默认会找这个文件夹
│   │   └── 【zqxt.png】
│   ├── tests.py
│   │
│   └── views.py
├── common_static # 已经添加到了 STATICFILES_DIRS 的文件夹
│   └── js
│       └── 【jquery.js】
│
├── dj18static
│   ├── __init__.py
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
└── manage.py

当 settings.py 中的 DEBUG = True 时,打开开发服务器 python manage.py runserver 直接访问 /static/zqxt.png 就可以找到这个静态文件。

也可以在settings.py中指定所有app共用的静态文件,比如jquery.js等。

STATICFILES_DIRS = (
    os.path.join(BASE_DIR, "common_static"),
)

把 jquery.js 放在 common_static/js/ 下,这样就可以 在 /static/js/jquery.js 中访问到它!


这里晕了好久,这里有三个文件夹,一是app下面的static,二是共用文件夹common_static,三是在运行python manage.py collectstatic 之后生成的collected_static。对于前两个,我们在公用文件夹下的静态文件,可以直接被app访问,只需将文件夹名,替换为static。


如果想为静态文件分配多个不同的网址时:
。。。。。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容