前言
靜態(tài)文件處理是每個(gè)網(wǎng)站都必備的步驟, django的靜態(tài)文件處理一般都遵循固定的套路, 這里分debug模式和非debug模式來說
通用配置
簡(jiǎn)單說下, settings.py
中一般會(huì)針對(duì)static有兩個(gè)配置:
STATIC_URL
- 可以理解為通過url訪問static文件的路徑
STATIC_ROOT
- 可以理解為你打算在服務(wù)器上存儲(chǔ)static文件的路徑(通過 python manage.py collectstatic命令)
除此之外, 在settings.py
同級(jí)的urls.py
內(nèi)還需要把STATIC_URL
和django的url連接起來, 通常:
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
urlpatterns += staticfiles_urlpatterns()
很簡(jiǎn)單, 就這么三步.
但這只是適用于常規(guī)配置.
怎么個(gè)常規(guī)法呢, 就是說你只有一個(gè)debug=True的環(huán)境(開發(fā)), 和一個(gè)debug=False的環(huán)境(生產(chǎn))
之所以提這個(gè)debug, 是因?yàn)槟銘?yīng)該了解, 把靜態(tài)文件丟給web server一起處理不是個(gè)明智的決定. 通常來說在開發(fā)的時(shí)候我們可以圖方便, 但是上了生產(chǎn)環(huán)境, 我們會(huì)把靜態(tài)文件都丟給諸如nginx這樣的反向代理來處理, 當(dāng)然也未必是nginx, 如果你采用了前后端分離, 用k8s分開部署, 也可以在ingress中為不同路徑配置請(qǐng)求的服務(wù).
如果認(rèn)真看了上述的staticfiles_urlpatterns
的函數(shù)其實(shí)也不難發(fā)現(xiàn), django對(duì)此的默認(rèn)配置其實(shí)就是只在debug=True的情況下允許訪問靜態(tài)資源, 在False時(shí)干脆關(guān)掉了這個(gè)url path.
這樣有點(diǎn)粗暴, 現(xiàn)實(shí)開發(fā)中也許我們會(huì)需要一個(gè)staging環(huán)境做預(yù)發(fā)布環(huán)境, 也許我們需要在這個(gè)環(huán)境上書寫api文檔, 這就意味著你在這個(gè)環(huán)境上也需要適當(dāng)訪問一些靜態(tài)資源.
因此就要對(duì)上述函數(shù)做寫改動(dòng), 讓其在特定環(huán)境下也開放static的訪問
重寫url
也很簡(jiǎn)單, 只要看一下原函數(shù)是怎么寫的, 把相應(yīng)部分改掉