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写的创建文件夹自定义函数mkdir()
Aug 25 Python
Python部署web开发程序的几种方法
May 05 Python
老生常谈进程线程协程那些事儿
Jul 24 Python
答题辅助python代码实现
Jan 16 Python
Django使用httpresponse返回用户头像实例代码
Jan 26 Python
python中的句柄操作的方法示例
Jun 20 Python
python异常触发及自定义异常类解析
Aug 06 Python
分享一个pycharm专业版安装的永久使用方法
Sep 24 Python
基于python中__add__函数的用法
Nov 25 Python
Python关于__name__属性的含义和作用详解
Feb 19 Python
关于Python turtle库使用时坐标的确定方法
Mar 19 Python
Selenium+BeautifulSoup+json获取Script标签内的json数据
Dec 07 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
解析PHP中intval()等int转换时的意外异常情况
2013/06/21 PHP
PHP 导出Excel示例分享
2014/08/18 PHP
PHP调试函数和日志记录函数分享
2015/01/31 PHP
微信公众平台开发之配置与请求
2015/08/26 PHP
如何用js控制css中的float的代码
2007/08/16 Javascript
toggle()隐藏问题的解决方法
2014/02/17 Javascript
Jquery方式获取iframe页面中的 Dom元素
2014/05/07 Javascript
JavaScript 获取任一float型小数点后两位的小数
2014/06/30 Javascript
js实现点击添加一个input节点
2014/12/05 Javascript
jquery自定义插件开发之window的实现过程
2016/05/06 Javascript
详解js中常规日期格式处理、月历渲染和倒计时函数
2016/12/28 Javascript
javascript 组合按键事件监听实现代码
2017/02/21 Javascript
从零开始做一个pagination分页组件
2017/03/15 Javascript
element-ui 文件上传修改文件名的方法示例
2019/11/05 Javascript
jQuery实现简易聊天框
2020/02/08 jQuery
jquery向后台提交数组的代码分析
2020/02/20 jQuery
Python实现多行注释的另类方法
2014/08/22 Python
跟老齐学Python之开始真正编程
2014/09/12 Python
Python素数检测的方法
2015/05/11 Python
详解Python中open()函数指定文件打开方式的用法
2016/06/04 Python
python多线程方式执行多个bat代码
2016/06/07 Python
详解python单元测试框架unittest
2018/07/02 Python
python3.4+pycharm 环境安装及使用方法
2019/06/13 Python
Python使用微信itchat接口实现查看自己微信的信息功能详解
2019/08/22 Python
Python numpy数组转置与轴变换
2019/11/15 Python
Python通过fnmatch模块实现文件名匹配
2020/09/30 Python
南京某软件公司的.net面试题
2015/11/30 面试题
文言文形式的学生求职信
2013/12/03 职场文书
2014全国两会学习心得体会2000字
2014/03/10 职场文书
党的群众路线教育实践活动学习计划
2014/11/03 职场文书
消防演习通知
2015/04/25 职场文书
会计继续教育培训心得体会
2016/01/19 职场文书
导游词之无锡梅园
2019/11/28 职场文书
2020年元旦祝福语录,总有适合你的
2019/12/31 职场文书
详解Django中 render() 函数的使用方法
2021/04/22 Python
Vue2.0搭建脚手架
2022/03/13 Vue.js