欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django 靜態(tài)文件配置過程詳解

 更新時間:2019年07月23日 11:00:58   作者:little_pd  
這篇文章主要介紹了Django 靜態(tài)文件配置過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

靜態(tài)文件配置

概述:

靜態(tài)文件交由Web服務器處理,Django本身不處理靜態(tài)文件。簡單的處理邏輯如下(以nginx為例):

URI請求 --> 按照Web服務器里面的配置規(guī)則先處理,以nginx為例,主要求配置在nginx.conf里的location

--> 如果是靜態(tài)文件,則由nginx直接處理

--> 如果不是則交由Django處理,Django根據urls.py里面的規(guī)則進行匹配

以上是部署到Web服務器后的處理方式,為了便于開發(fā),Django提供了在開發(fā)環(huán)境的對靜態(tài)文件的處理機制,方法如下:

static配置:

STATIC主要指的是如css、js、images這樣文件:

STATIC_URL = '/static/' # 別名

STATICFILES_DIRS = [
  os.path.join(BASE_DIR, "static"), # 實際名,即實際文件夾的名字
]
# 注意:django對引用名和實際名進行映射,引用時,只能按照引用名來,不能按實際名去找

media配置:

MEDIA_URL = "/media/"

# 用戶上傳的文件(針對models.py中的FileField、ImageField字段)保存到哪
MEDIA_ROOT = os.path.join(BASE_DIR, "app名字", "media")
# 配合settings.py里的MEDIA_URL = "/media/"配置,即對外開放了這個接口的權限
from django.conf.urls import url
from django.views.static import serve
from . import settings

urlpatterns = [
  url(r'^media/(?P<path>.*)$', serve, {"document_root": settings.MEDIA_ROOT}),
]

ps:

靜態(tài)文件的處理又包括STATIC和MEDIA兩類,這往往容易混淆,在Django里面是這樣定義的:

MEDIA:指用戶上傳的文件,比如在Model里面的FileFIeld,ImageField上傳的文件。如果你定義

MEDIA_ROOT = c:\temp\media,那么File=models.FileField(upload_to="abc/")#,上傳的文件就會被保存到

c:\temp\media\abc
eg:
class blog(models.Model):
Photo = models.ImageField(upload_to="photo")

上傳的圖片就上傳到c:\temp\media\photo,而在模板中要顯示該文件,則在settings里面設置MEDIA_ROOT(必須是本地路徑的絕對路徑),一般是這樣寫:

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

MEDIA_URL是指從瀏覽器訪問時的地址前綴,舉個例子:

    MEDIA_ROOT = c:\temp\media\photo
    MEDIA_URL = "/data/"

在開發(fā)階段,media的處理由django處理:

訪問http://localhost/data/abc/a.png就是訪問c:\temp\media\photo\abc\a.png

在模板里面這樣寫<img src="/media/abc/a.png">

在部署階段最大的不同在于你必須讓web服務器來處理media文件,因此你必須在web服務器中配置,

以便能讓web服務器能訪問media文件。

以nginx為例,可以在nginx.conf里面這樣:

       location ~/media/{
          root/temp/
          break;
        }

具體可以參考如何在nginx部署django的資料。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

最新評論