国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

分離django中的媒體文件,靜態文件和網頁

yuanzhanghu / 3268人閱讀

摘要:前言文章會在中持續更新作者聯系我項目中,占很大體積的是靜態文件,媒體文件還有代碼,那我們該如何把它們分離出來以方便我們和服務器去管理和使用它們。

前言

文章會在github中持續更新

作者: knthony

github

聯系我

django項目中,占很大體積的是靜態文件,媒體文件還有html代碼,那我們該如何把它們分離出來以方便我們和服務器去管理和使用它們。

static 文件

static,顧名思義就是靜態文件,django自帶了一個命令講項目中所有的靜態文件提取出來
python3 manage.py collectstatic

我習慣將這些可以從外部引入的文件放在項目的根目錄下

DemoProject
--DemoProject
--DemoApp
--static
--manage.py

是的,就是它,我喜歡的位置。
不過在此之前,我們需要在項目的setting.py中去設置提取文件所要存儲的位置STATIC_ROOT

STATIC_ROOT = os.path.join(BASE_DIR, "static")

那這樣,我們運行完上面的命令就會發現我們的項目結構中會多一個static文件
然后配置DemoProject下的url,添加

from django.contrib.staticfiles.urls import staticfiles_urlpatterns
from django.conf.urls.static import static
from django.conf import settings


urlpatterns = [
    url(r"^admin/", admin.site.urls),
]


if settings.DEBUG or True:
    urlpatterns += staticfiles_urlpatterns()

當然這個if判斷是在debug為true的時候支持這樣的訪問,那如果在真實生產環境中需要修改遮蓋判斷
不過到這里還沒有結束,為了方便的引用我們需要在setting.py中添加

STATICFILES_DIRS = [
    ("bootstrap",os.path.join(BASE_DIR, "static/bootstrap").replace("","/")),
]

注意這種方式在html中可以直接以如下方式訪問

注意要在第一行加上{% load staticfiles %}

media文件

網站上總是會有音樂視頻或者圖片等體積比較大的文件,那我們將這些也從django項目中分離出來并進行調用
首先我們在和static同目錄下新建一個media文件夾,在media中新建一個image作為我們存放圖片的文件夾
結構如下:

DemoProject
--DemoProject
--DemoApp
--static
--media
---image
--manage.py

第一步:在setting.py最后添加

MEDIA_URL = "/media/"
MEDIA_ROOT = os.path.join(BASE_DIR, "media")

第二部:在urls.py
urlpatterns += staticfiles_urlpatterns()
下面添加
urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

說出來你可能不信,這樣就ok了

這樣就可以訪問我們的media/image下的圖片或者視頻了

templates

如果我們想把項目中的網頁代碼文件歸類分離出來
第一步:

TEMPLATES = [
    {
        "BACKEND": "django.template.backends.django.DjangoTemplates",
        "DIRS": [
            os.path.join(BASE_DIR, "templates").replace("","/"),
        ],
        "APP_DIRS": True,
        "OPTIONS": {
            "context_processors": [
                "django.template.context_processors.debug",
                "django.template.context_processors.request",
                "django.contrib.auth.context_processors.auth",
                "django.contrib.messages.context_processors.messages",
            ],
        },
    },
]

在上面代碼的DIRS中添加你網頁代碼的路徑,如果也想和我一樣放在根路徑下可以和我一樣

os.path.join(BASE_DIR, "templates").replace("","/"),

這是最近寫django項目總結的一點點,第一次寫文章,大牛勿噴,感謝大牛能指出文中的缺漏和錯誤

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/38198.html

相關文章

  • Django項目前端工程化的探索

    摘要:項目前端工程化的探索不通過層實現非網頁開發的前后端分離。做過這樣項目的各位攻城獅應該都知道有多痛苦吧。仔細想來,其實只是想要模板和靜態資源,我們可以直接在目錄下寫,當然也可以開一個前端工程來寫,最后把模板和靜態資源到工程的相應目錄下。 Django項目前端工程化的探索 不通過node層實現非SPA網頁開發的前后端分離。 技術棧:webpack + jade + es6 + scss +...

    jsummer 評論0 收藏0
  • Django項目前端工程化的探索

    摘要:項目前端工程化的探索不通過層實現非網頁開發的前后端分離。做過這樣項目的各位攻城獅應該都知道有多痛苦吧。仔細想來,其實只是想要模板和靜態資源,我們可以直接在目錄下寫,當然也可以開一個前端工程來寫,最后把模板和靜態資源到工程的相應目錄下。 Django項目前端工程化的探索 不通過node層實現非SPA網頁開發的前后端分離。 技術棧:webpack + jade + es6 + scss +...

    buildupchao 評論0 收藏0
  • Django項目前端工程化的探索

    摘要:項目前端工程化的探索不通過層實現非網頁開發的前后端分離。做過這樣項目的各位攻城獅應該都知道有多痛苦吧。仔細想來,其實只是想要模板和靜態資源,我們可以直接在目錄下寫,當然也可以開一個前端工程來寫,最后把模板和靜態資源到工程的相應目錄下。 Django項目前端工程化的探索 不通過node層實現非SPA網頁開發的前后端分離。 技術棧:webpack + jade + es6 + scss +...

    Jackwoo 評論0 收藏0
  • Django項目前端工程化的探索

    摘要:項目前端工程化的探索不通過層實現非網頁開發的前后端分離。做過這樣項目的各位攻城獅應該都知道有多痛苦吧。仔細想來,其實只是想要模板和靜態資源,我們可以直接在目錄下寫,當然也可以開一個前端工程來寫,最后把模板和靜態資源到工程的相應目錄下。 Django項目前端工程化的探索 不通過node層實現非SPA網頁開發的前后端分離。 技術棧:webpack + jade + es6 + scss +...

    HackerShell 評論0 收藏0
  • uwsgi+nginx項目部署

    摘要:部署項目部署一個的開源框架。輪詢負載均衡在配置文件中添加如下配置,此配置有三臺服務器提供支付服務。缺省配置就是輪詢策略負載均衡支持和協議,只需要修改后面的協議即可支持的負載均衡只需將改為即可。 部署Django項目 Django+uWSGI+nginx 部署 django 一個pyhton的開源web框架。 uWSGI 一個基于自有的uwsgi協議、WSGI協議和http服務協議的w...

    betacat 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<