2015-4-4阅读177 评论1css
先聊聊吧,做为一名程序猿,最近在一我的在帮企业写网站,用的架构呢,是:mongodb + python + django + html。以前搞网页,图片,css文件,js文件的路径是直接相对于***.html文件的,没想到等到真正要部署到 django的服务器上,全部的图片所有没法显示。css文件和js文件一样没有效果。html
搞了两三天,终于解决了这个问题。python
程序猿容易吗?不容易,老是被各类小问题被捆住了手脚,而没有把真正的精力用在:算法,并发,大数据 处理,内存优化这些问题上,老是被大多数人经历的小问题再次重复经历,这是一条老路。算法
个人想法就是:经过几分钟告诉你问题的缘由和解决方法,让一个可能在你身上须要几天解决的问题,几分钟解决,把精力花在一个程序猿应该花的身上。若是以为好,不妨不要吝啬您的一两句评论。mongodb
只有程序猿才能理解程序猿是多么的。。。django
缘由:django部署方式比较特别,采用静态文件路径:STATICFILES_DIRS的部署方式,以前你写的相对路径,绝对路径由于缺乏静态文件路径而所有失效服务器
解决方法:架构
步骤1:在settings.py文件的最后加上如下内容:并发
STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(os.path.dirname(__file__),'static')
# 设置图片等静态文件的路径
STATICFILES_DIRS = (
('css',os.path.join(STATIC_ROOT,'css').replace('\\','/') ),
('js',os.path.join(STATIC_ROOT,'js').replace('\\','/') ),
('images',os.path.join(STATIC_ROOT,'images').replace('\\','/') ),
('upload',os.path.join(STATIC_ROOT,'upload').replace('\\','/') ),
)app
步骤2:在urls.py文件的开头第一行和第二行分别加上如下内容:
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
from django.contrib import staticfiles
在urls.py文件最后加上如下内容:
#设置静态文件路径
urlpatterns += staticfiles_urlpatterns()
步骤3:设置静态文件的目录,很关键
整个文件的目录结构以下
project---project
---app
|
----static
|
-----templates
你的static和templates处于同级目录,而后将你的images,css,js文件夹放在static目录下面
测试:在你模板,也就是html文件中
<p><img src="/static/images/bg_information.png.png" width="980" height="180"></p>
改为本身的图片名称,注意图片前缀:/static/images/ 别写成 static/images/ 这样会没法显示
大功告成,嗨起来。