利用django-suit模板添加自定義的菜單、頁面及設(shè)置訪問權(quán)限
前言
本文主要給大家介紹了利用django-suit模板在管理后臺添加自定義的菜單和自定義的頁面、設(shè)置訪問權(quán)限的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來隨著小編一起看看詳細(xì)的介紹吧
方法如下:
1、先在settings.py里面的SUIT_CONFIG中添加配置,我們平時添加的配置都是app類型的,我們需要自定義頁面的話,就不能用app了,需要用url,這里面我們使用如下:
# django-suit config SUIT_CONFIG = { 'ADMIN_NAME': 'X·X', 'HEADER_DATE_FORMAT': '', 'HEADER_TIME_FORMAT': 'H:i', 'SHOW_REQUIRED_ASTERISK': True, 'CONFIRM_UNSAVED_CHANGES': True, 'LIST_PER_PAGE': 20, 'MENU_OPEN_FIRST_CHILD': True, 'MENU': ( # sites是默認(rèn)原先的app和models # 'sites', '-', {'app': 'auth', 'label': u'權(quán)限管理', 'icon': 'icon-lock'}, '-', {'app': 'duser', 'label': u'平臺用戶', 'icon': 'icon-user'}, '-', {'app': 'dtheme', 'label': u'主題管理', 'icon': 'icon-tags'}, '-', {'app': 'dpost', 'label': u'文章管理', 'icon': 'icon-edit'}, '-', # 如果使用http這種絕對路徑的話,菜單不會展開,且不會標(biāo)記為active狀態(tài) {'url': '/admin/theme/mysql', 'label': u'第三數(shù)據(jù)', 'icon': 'icon-lock'}, '-', {'label': u'統(tǒng)計(jì)數(shù)據(jù)', 'icon': 'icon-tags', 'models': ( {'url': '/admin/theme/data', 'label': u'第一數(shù)據(jù)'}, {'url': '/admin/theme/show', 'label': u'第二數(shù)據(jù)'} )} ) }
2、然后就是在urls.py里面添加路由,這個路由一定要添加在admin.site.urls的前面,因?yàn)椴蝗坏脑挘鼤热dmin.site.urls里面去匹配,造成混亂或報(bào)錯。
from dtheme import views urlpatterns = [ # 第一個就是我們自己新增的url路徑 url(r'^admin/theme/data', views.data), url(r'^admin/', admin.site.urls), url(r'^api/user/', include('duser.urls')), url(r'^api/post/', include('dpost.urls')), url(r'^api/theme/', include('dtheme.urls')), ] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
3、然后,就是寫views了,我們假如dtheme模塊的views里面寫:
def data(request): return render(request, "data.html")
4、請注意,之所以我們上面可以直接用data.html,是因?yàn)槲覀冊赿theme模塊下面創(chuàng)建了一個templates文件夾,然后把data.html放在里面了,它會掃描這個文件夾找模板。那么這個模板寫成什么樣呢?我們就隨意寫了一個東西。這里面需要注意的是,我們需要繼承base_site.html,不然那些header和footer,還有左邊的菜單什么的都沒有了,相當(dāng)于誰也不繼承。內(nèi)容就寫在content里面即可。
{% extends "admin/base_site.html" %} {% block content %} hello, new page. {% endblock %}
5、OVER。
6、回來,還沒完。這個時候如果我們從后臺注銷,然后直接在瀏覽器中輸入http://127.0.0.1:8000/admin/theme/data的話,發(fā)現(xiàn)還是可以直接訪問到這個頁面,輸入管理后臺的其他頁面它就會要求你驗(yàn)證。所以說我們自定義的這個頁面還是十分危險(xiǎn)的,其他人知道網(wǎng)址后就可以直接訪問它了,我們的想法其實(shí)也很簡單啊,我們也不想搞特殊,在安全這方面,只要求和其他后臺的頁面一樣就行了:即用戶在訪問這些后臺頁面的時候要做一個用戶驗(yàn)證,如果用戶已經(jīng)登錄了,就可以訪問,沒登錄沒通過驗(yàn)證的話,就不能訪問,直接跳轉(zhuǎn)到登錄頁面。這個需要我們再view里面做設(shè)置。
from django.contrib.admin.views.decorators import staff_member_required def data(request): return render(request, "data.html") data = staff_member_required(data)
看到上面的變化了沒有?就是我們引入了一個staff_member_required模塊,這個模塊就是用來驗(yàn)證是否是內(nèi)部人員(也就是是否登錄)用的。當(dāng)然我們要把我們的view函數(shù)放在它里面。這樣就OK了。
7、這里面還有一個如何把自定義頁面加入到auth里面的坑,待研究完再回來補(bǔ)充。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
淺談Python2.6和Python3.0中八進(jìn)制數(shù)字表示的區(qū)別
下面小編就為大家?guī)硪黄獪\談Python2.6和Python3.0中八進(jìn)制數(shù)字表示的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04Python編程實(shí)現(xiàn)從字典中提取子集的方法分析
這篇文章主要介紹了Python編程實(shí)現(xiàn)從字典中提取子集的方法,結(jié)合實(shí)例形式對比分析了Python采用字典推導(dǎo)式與序列轉(zhuǎn)換實(shí)現(xiàn)字典提取子集的相關(guān)操作技巧與優(yōu)缺點(diǎn),需要的朋友可以參考下2018-02-02python matplotlib 畫dataframe的時間序列圖實(shí)例
今天小編就為大家分享一篇python matplotlib 畫dataframe的時間序列圖實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11python 捕獲 shell/bash 腳本的輸出結(jié)果實(shí)例
下面小編就為大家?guī)硪黄猵ython 捕獲 shell/bash 腳本的輸出結(jié)果實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01