Djang中静态文件配置方法


Posted in Python onJuly 30, 2015

下面通过图文并茂的方法给大家详细介绍下Djang中静态文件配置方法

一、django静态文件配置原理
静态文件配置就是为了让用户请求时django服务器能找到静态文件返回。

首先要理解几个概念:

媒体文件:用户上传的文件
静态文件:css,js,image等
开发环境:使用django内置服务器处理静态文件
生产环境:使用apache2/nginx服务器处理静态文件映射
所以在配置时要分清楚开发环境还是生产环境,这个后面会详细介绍。

下面先介绍一下服务器查找静态文件的原理,这样我们才能更好的配置。

1、django.contrib.staticfiles
django.contrib.staticfiles是django1.3新增的一个app来帮助开发者管理静态文件【js,css等】。

django1.3之前的静态文件都是用MEDIA_URL和MEDIA_ROOT来控制的。

为了将媒体文件【用户上传的文件】和静态文件做区分,django1.3通过MEDIA_XXX配置来处理媒体文件,通过STATIC_XXX配置项来处理静态文件。

staticfiles使开发者可以将静态文件分配到app目录或任意指定目录。

2、MEDIA_XXX和STATIC_XXX配置项的区别
MEDIA_XXX配置项用来管理媒体文件。经常由FileFields字段上传,它们被保存在settings.MEDIA_ROOT指定的目录下,通过settings.MEDIA_URL指定的路径访问。

STATIC_XXX配置项用来管理静态文件。它们通过manage.py collectstatic命令汇集到settings.STATIC_ROOT目录,并通过settings.STATIC_URL指定的路径访问。

3、 静态文件相关配置项详解
STATIC_ROOT配置项

用来指定执行manage.py collectstatic时静态文件存放的路径。在生成环境中,集中存放静态资源有利于使用Lighttpd/Nginx/apache2托管静态资源。为了方便调试,通常设置如下:

SITE_ROOT = os.path.dirname(os.path.abspath(__file__))

SITE_ROOT = os.path.abspath(os.path.join(SITE_ROOT, '../'))

STATIC_ROOT = os.path.join(SITE_ROOT, 'collectedstatic')

STATIC_URL配置项

django模板中,可以引用{{STATIC_URL}}变量避免把路径写死。通常使用默认设置

STATIC_URL = '/static/'

ADMIN_MEDIA_PREFIX配置项

ADMIN_MEDIA_PREFIX必须为如下配置,以便staticfiles能够正确找到django.contrib.admin的静态资源:

ADMIN_MEDIA_PREFIX = STATIC_URL + 'admin/'

 在模板中使用STATIC_URL
<link rel="stylesheet" href="{{ STATIC_URL }}css/core.css">

原理懂了后,接下来介绍开发环境和生产环境中静态文件具体配置。

我的django版本是1.4.21,以此版本做介绍。

>>> import django

>>> print django.get_version()

1.4.21

二、开发环境
django1.4,21中默认已安装了staticfiles app,所以开发环境中对静态文件的访问不需要对django做任何配置。

有一点:开发环境staticfiles查找静态文件的顺序取决于STATIC_FINDERS配置项,默认配置

STATICFILES_FINDERS = (

    'django.contrib.staticfiles.finders.FileSystemFinder',

    'django.contrib.staticfiles.finders.AppDirectoriesFinder',

#    'django.contrib.staticfiles.finders.DefaultStorageFinder',

)

FileStstemFinder用来用STATICFILES_DIRS【默认为空】指定的路径中查找额外的静态文件。像jquery,bootstrap等这样公用的资源文件都是在多个不同的app中共用的,django提供了公有的目录来放这些文件,这个配置参数就是:STATICFILES_DIRS
AppDirectoriesFinder从INSTALLED_APPS元组中的APP所在包的static目录中查找资源文件。
使用如下。

1、新建项目lxyproject

[root@yl-web srv]# django-admin.py startproject lxyproject

2、在项目中新建一个app名叫hello
[root@yl-web lxyproject]# python manage.py startapp hello

[root@yl-web lxyproject]# ls

hello  lxyproject  manage.py

在hello app下建一个static目录用来存放静态文件。

[root@yl-web hello]# mkdir static

[root@yl-web hello]# ls

__init__.py  models.py  static  tests.py  views.py

然后在static目录新建一个hello.txt的静态文件。
[root@yl-web hello]# cd static/

[root@yl-web static]# ls

hello.txt

[root@yl-web static]# cat hello.txt 

hello.txt's content:congratulations!!

3、在项目的settings.py文件中INSTALLED_APPS中配置hello app
INSTALLED_APPS = (

    ...

    'hello',

)

4、运行项目
[root@yl-web lxyproject]# python manage.py runserver 0.0.0.0:9000

5、通过url访问

Djang中静态文件配置方法

在static目录下新建一个images目录放一张sheep.png图片,同理通过url访问

Djang中静态文件配置方法

三、生产环境
前面也说了,在生成环境中,集中存放静态资源有利于使用Lighttpd/Nginx托管静态资源。而生产环境一般是把静态文件放在项目根目录下的static目录下。

默认配置

STATIC_ROOT = ''

STATIC_URL = '/static/'

STATICFILES_DIRS = (

)

我们要做的是

1、配置服务器,我用的是apache。

安装配置详情可参考:

Ubuntu apache2服务器配置

centos7 apache httpd安装和配置django项目

2、在项目根目录下创建collectedstatic目录。

3、配置settings.py

import os

SITE_ROOT = os.path.dirname(os.path.abspath(__file__))
SITE_ROOT = os.path.abspath(os.path.join(SITE_ROOT, '../'))
STATIC_ROOT = os.path.join(SITE_ROOT, 'collectedstatic')
STATIC_URL = '/static/'
STATICFILES_DIRS = (
 # Put strings here, like "/home/html/static" or "C:/www/django/static".
 # Always use forward slashes, even on Windows.
 # Don't forget to use absolute paths, not relative paths.
)
INSTALLED_APPS = (
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.sites',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 # Uncomment the next line to enable the admin:
 # 'django.contrib.admin',
 # Uncomment the next line to enable admin documentation:
 # 'django.contrib.admindocs',
 'hello',
)

 
4、运行python manage.py collectstatic收集所有已安装的APP的静态文件到根目录的collectedstatic【即STATIC_ROOT】中

 

[root@yl-web lxyproject]# python manage.py collectstatic

You have requested to collect static files at the destination

location as specified in your settings.

This will overwrite existing files!

Are you sure you want to do this?

Type 'yes' to continue, or 'no' to cancel: yes

Copying '/srv/lxyproject/hello/static/images/sheep.png'

1 static file copied.
 
5、配置服务器,将/static/路径指向STATIC_ROOT目录。

即在虚拟主机中配置

Alias /static/ /srv/lxyproject/collectedstatic/

6、配置至此完成,通过浏览器访问

 Djang中静态文件配置方法

真正发布一个django项目时,对静态文件的管理可能需要额外做一些工作:

Less / CoffeeScript 等自动编译成css/js
"压缩" css/js文件,提高浏览器加载速度
合并零碎的css/js文件,减少浏览器请求次数
静态资源文件的版本话:浏览器会缓存静态文件,后台代码和静态资源文件都发生更新后,浏览器很可能从缓存提取过期的静态资源,导致页面显示异常。

以上就是Djang中静态文件配置方法的全部内容,希望大家喜欢。

Python 相关文章推荐
python使用新浪微博api上传图片到微博示例
Jan 10 Python
Python实现将sqlite数据库导出转成Excel(xls)表的方法
Jul 17 Python
python中import reload __import__的区别详解
Oct 16 Python
Python线性回归实战分析
Feb 01 Python
Python常见MongoDB数据库操作实例总结
Jul 24 Python
Python Learning 列表的更多操作及示例代码
Aug 22 Python
Python3.4学习笔记之 idle 清屏扩展插件用法分析
Mar 01 Python
django一对多模型以及如何在前端实现详解
Jul 24 Python
Keras中的两种模型:Sequential和Model用法
Jun 27 Python
python如何代码集体右移
Jul 20 Python
Python使用windows设置定时执行脚本
Nov 12 Python
Pytorch中TensorBoard及torchsummary的使用详解
May 12 Python
Python实现根据IP地址和子网掩码算出网段的方法
Jul 30 #Python
Python实现配置文件备份的方法
Jul 30 #Python
Python统计文件中去重后uuid个数的方法
Jul 30 #Python
Python利用正则表达式匹配并截取指定子串及去重的方法
Jul 30 #Python
Python实现简单拆分PDF文件的方法
Jul 30 #Python
使用Python脚本生成随机IP的简单方法
Jul 30 #Python
Python实现批量读取word中表格信息的方法
Jul 30 #Python
You might like
php创建session的方法实例详解
2015/01/27 PHP
Javascript 匿名函数及其代码模式原理
2010/03/19 Javascript
30个让人兴奋的视差滚动(Parallax Scrolling)效果网站
2012/03/04 Javascript
js移除事件 js绑定事件实例应用
2012/11/28 Javascript
jquery实现的带缩略图的焦点图片切换(自动播放/响应鼠标动作)
2013/01/23 Javascript
$.getJSON在IE下失效的原因分析及解决方法
2013/06/16 Javascript
javascript对JSON数据排序的3个例子
2014/04/12 Javascript
jQuery实现为控件添加水印文字效果(附源码)
2015/12/02 Javascript
第一次接触神奇的Bootstrap基础排版
2016/07/26 Javascript
jQuery继承extend用法详解
2016/10/10 Javascript
JS三目运算(三元运算)方法详解
2017/03/01 Javascript
聊聊JavaScript如何实现继承及特点
2017/04/07 Javascript
javaScript手机号码校验工具类PhoneUtils详解
2017/12/08 Javascript
小程序自定义导航栏兼容适配所有机型(附完整案例)
2020/04/26 Javascript
Jquery+AJAX实现无刷新上传并重命名文件操作示例【PHP后台接收】
2020/05/29 jQuery
微信小程序反编译的实现
2020/12/10 Javascript
python脚本实现统计日志文件中的ip访问次数代码分享
2014/08/06 Python
Python导出数据到Excel可读取的CSV文件的方法
2015/05/12 Python
Pyspider中给爬虫伪造随机请求头的实例
2018/05/07 Python
python字符串常用方法
2018/06/14 Python
python使用adbapi实现MySQL数据库的异步存储
2019/03/19 Python
Python中@property的理解和使用示例
2019/06/11 Python
PyTorch中model.zero_grad()和optimizer.zero_grad()用法
2020/06/24 Python
浅谈keras使用预训练模型vgg16分类,损失和准确度不变
2020/07/02 Python
玩具反斗城葡萄牙官方商城:Toys"R"Us葡萄牙
2016/10/21 全球购物
帕克纽约:PARKER NY
2018/12/09 全球购物
如何将整数int转换成字串String
2014/03/21 面试题
幼儿园义卖活动方案
2014/01/17 职场文书
高中生物教学反思
2014/02/05 职场文书
园林设计专业毕业生求职信
2014/03/23 职场文书
大学辅导员述职报告
2015/01/10 职场文书
数学备课组工作总结
2015/08/12 职场文书
十大最强妖精系宝可梦,哲尔尼亚斯实力最强,第五被称为大力士
2022/03/18 日漫
安装Windows Server 2012 R2企业版操作系统并设置好相关参数
2022/04/29 Servers
Java 定时任务技术趋势简介
2022/05/04 Java/Android
解决Git推送错误non-fast-forward的方法
2022/06/25 Servers