首页 > 代码库 > django关闭debug后,静态文件的处理
django关闭debug后,静态文件的处理
Django框架仅在开发模式下提供静态文件服务。当我开启DEBUG模式时,Django内置的服务器是提供静态文件的服务的,所以css等文件访问都没有问题,但是关闭DEBUG模式后,Django便不提供静态文件服务了。
1.使用django.views.static.serve()方法。在URLconf中添加:
编辑usrs.py,在最后添加如下代码:
from django.conf import settingsif settings.DEBUG is False: urlpatterns += patterns(‘‘, url(r‘^static/(?P<path>.*)$‘, ‘django.views.static.serve‘, { ‘document_root‘: settings.STATIC_ROOT, }), )
修改settings.py中的设置:
方法一(写死STATIC_ROOT):
STATIC_ROOT = ‘C:/Django/workplace/sf/sinfors/static‘
方法二(但是/admin的样式就不能用了):
if DEBUG: STATIC_URL = ‘static/‘else: STATIC_URL = ‘sinfors/static/‘STATIC_ROOT= os.path.join(BASE_DIR,STATIC_URL)
2.直接改变运行方式:(--insecure参数强制django处理静态文件,推荐)
python manage.py runserver 0.0.0.0:80 --insecure
3.使用项目正式部署是所使用的配置,由apache提供静态文件服务:
将静态文件由apache提供文件服务(类似正式部署):
编辑/etc/apache2/sites-available/horizon文件:
#Alias /media /opt/stack/horizon/openstack_dashboard/static
Alias /static /opt/stack/horizon/openstack_dashboard/static
建立静态文件链接:
ln -sv /opt/stack/horizon/openstack_dashboard/static /opt/stack/horizon
重启apache:
sudo service apache2 restart
django关闭debug后,静态文件的处理
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。