解決django關於圖片無法顯示的問題


http://python.usyiyi.cn/django/index.html

http://m.blog.csdn.net/blog/qingyuanluofeng/44877399

http://www.idjango.com/content/15/

[原]手把手教你:解決django關於圖片無法顯示的問題

2015-4-4閱讀177 評論1

先聊聊吧,作為一名程序猿,最近在一個人在幫企業寫網站,用的架構呢,是:mongodb + python + django + html。之前搞網頁,圖片,css文件,js文件的路徑是直接相對於***.html文件的,沒想到等到真正要部署到 django的服務器上,所有的圖片全部無法顯示。css文件和js文件同樣沒有效果。

搞了兩三天,終於解決了這個問題。

程序猿容易嗎?不容易,總是被各種小問題被捆住了手腳,而沒有把真正的精力用在:算法,並發,大數據 處理,內存優化這些問題上,總是被大多數人經歷的小問題再次重復經歷,這是一條老路。

我的想法就是:通過幾分鍾告訴你問題的原因和解決方法,讓一個可能在你身上需要幾天解決的問題,幾分鍾解決,把精力花在一個程序猿應該花的身上。如果覺得好,不妨不要吝嗇您的一兩句評論。

只有程序猿才能理解程序猿是多么的。。。

 

原因: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('\\','/') ),
)

步驟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/ 這樣會無法顯示

 

大功告成,嗨起來。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM