django美化后台django-suit的安装配置操作


Posted in Python onJuly 12, 2020

环境:python2.7+django1.9

1、先下载django-suti

pip install django-suit

2、配置项目

打开setting.py,然后找到------------------------INSTALLED_APPS

在'django.contrib.admin',前面写入 'suit',

INSTALLED_APPS = [
 'suit',
 'django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',

]

修改语言、地区、时间格式:

LANGUAGE_CODE = 'zh-Hans'
TIME_ZONE = 'Asia/Shanghai'
DATETIME_FORMAT = 'Y-m-d H:i:s' 
DATE_FORMAT = 'Y-m-d'

补充知识:利用django-suit模板在管理后台添加自定义的菜单和自定义的页面、设置访问权限

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是默认原先的app和models
  # 'sites',
  '-',
  {'app': 'auth', 'label': u'权限管理', '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这种绝对路径的话,菜单不会展开,且不会标记为active状态
  {'url': '/admin/theme/mysql', 'label': u'第三数据', 'icon': 'icon-lock'},
  '-',
  {'label': u'统计数据', 'icon': 'icon-tags', 'models': (
   {'url': '/admin/theme/data', 'label': u'第一数据'},
   {'url': '/admin/theme/show', 'label': u'第二数据'}
  )}
 )
}

2、然后就是在urls.py里面添加路由,这个路由一定要添加在admin.site.urls的前面,因为不然的话,它会先去admin.site.urls里面去匹配,造成混乱或报错。

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,是因为我们在dtheme模块下面创建了一个templates文件夹,然后把data.html放在里面了,它会扫描这个文件夹找模板。那么这个模板写成什么样呢?我们就随意写了一个东西。这里面需要注意的是,我们需要继承base_site.html,不然那些header和footer,还有左边的菜单什么的都没有了,相当于谁也不继承。内容就写在content里面即可。

{% extends "admin/base_site.html" %}

{% block content %}
hello, new page.
{% endblock %}

5、OVER。

6、回来,还没完。这个时候如果我们从后台注销,然后直接在浏览器中输入http://127.0.0.1:8000/admin/theme/data的话,发现还是可以直接访问到这个页面,输入管理后台的其他页面它就会要求你验证。所以说我们自定义的这个页面还是十分危险的,其他人知道网址后就可以直接访问它了,我们的想法其实也很简单啊,我们也不想搞特殊,在安全这方面,只要求和其他后台的页面一样就行了:即用户在访问这些后台页面的时候要做一个用户验证,如果用户已经登录了,就可以访问,没登录没通过验证的话,就不能访问,直接跳转到登录页面。这个需要我们再view里面做设置。

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模块,这个模块就是用来验证是否是内部人员(也就是是否登录)用的。当然我们要把我们的view函数放在它里面。这样就OK了。

7、这里面还有一个如何把自定义页面加入到auth里面的坑,待研究完再回来补充。

以上这篇django美化后台django-suit的安装配置操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python使用三角迭代计算圆周率PI的方法
Mar 20 Python
举例讲解Python中is和id的用法
Apr 03 Python
Python中函数参数设置及使用的学习笔记
May 03 Python
Python使用回溯法子集树模板解决爬楼梯问题示例
Sep 08 Python
Python pyinotify日志监控系统处理日志的方法
Mar 08 Python
django主动抛出403异常的方法详解
Jan 04 Python
Python+OpenCV图片局部区域像素值处理改进版详解
Jan 23 Python
python 获得任意路径下的文件及其根目录的方法
Feb 16 Python
使用python模拟高斯分布例子
Dec 09 Python
python通过安装itchat包实现微信自动回复收到的春节祝福
Jan 19 Python
python RSA加密的示例
Dec 09 Python
python利用后缀表达式实现计算器功能
Feb 22 Python
浅谈matplotlib 绘制梯度下降求解过程
Jul 12 #Python
使用matplotlib的pyplot模块绘图的实现示例
Jul 12 #Python
django template实现定义临时变量,自定义赋值、自增实例
Jul 12 #Python
Django后端分离 使用element-ui文件上传方式
Jul 12 #Python
PyQt5-QDateEdit的简单使用操作
Jul 12 #Python
Python logging日志模块 配置文件方式
Jul 12 #Python
django rest framework 过滤时间操作
Jul 12 #Python
You might like
为查询结果建立向后/向前按钮
2006/10/09 PHP
PHP生成网页快照 不用COM不用扩展.
2010/02/11 PHP
php开启与关闭错误提示适用于没有修改php.ini的权限
2014/10/16 PHP
php记录搜索引擎爬行记录的实现代码
2018/03/02 PHP
Linux下源码包安装Swoole及基本使用操作图文详解
2019/04/02 PHP
extjs 初始化checkboxgroup值的代码
2011/09/21 Javascript
基于jquery和svg实现超炫酷的动画特效
2014/12/09 Javascript
jquery判断输入密码两次是否相等
2020/04/22 Javascript
js实现滚动条滚动到页面底部继续加载
2015/12/19 Javascript
基于Vue2的独立构建与运行时构建的差别(详解)
2017/12/06 Javascript
JS中Map和ForEach的区别
2018/02/05 Javascript
Bootstrap Paginator+PageHelper实现分页效果
2018/12/29 Javascript
微信小程序如何使用canvas二维码保存至手机相册
2019/07/15 Javascript
基于原生js实现判断元素是否有指定class名
2020/07/11 Javascript
vue抽出组件并传值实例
2020/07/31 Javascript
跟老齐学Python之关于类的初步认识
2014/10/11 Python
Python的Flask站点中集成xhEditor文本编辑器的教程
2016/06/13 Python
python 删除指定时间间隔之前的文件实例
2018/04/24 Python
Python面向对象之类和实例用法分析
2019/06/08 Python
Django框架静态文件使用/中间件/禁用ip功能实例详解
2019/07/22 Python
Python使用APScheduler实现定时任务过程解析
2019/09/11 Python
Pandas DataFrame中的tuple元素遍历的实现
2019/10/23 Python
PyCharm第一次安装及使用教程
2020/01/08 Python
np.random.seed() 的使用详解
2020/01/14 Python
Python求区间正整数内所有素数之和的方法实例
2020/10/13 Python
HTML5中的Article和Section元素认识及使用
2013/03/22 HTML / CSS
手机配件第一品牌:ZAGG
2017/05/28 全球购物
美味咖啡的顶级烘焙师:Cafe Britt
2018/03/15 全球购物
美国女士时尚珠宝及配饰购物网站:Icing
2018/07/02 全球购物
电子商务专业自我鉴定
2013/12/18 职场文书
实习指导老师评语
2014/04/26 职场文书
高中军训的心得体会
2014/09/01 职场文书
个人贷款授权委托书样本
2014/10/07 职场文书
检讨书格式
2015/01/23 职场文书
2015年小学生自我评价范文
2015/03/03 职场文书
PyCharm配置KBEngine快速处理代码提示冲突、配置命令问题
2021/04/03 Python