自动化监控系统搭建xadmin做网站后台

爬行的龟 爬行的龟     2022-08-27     690

关键词:

Django有个自带的admin后台,不过界面不怎么好看,这里我用xadmin

 

我的python版本是3.5,可以使用支持py3的xadmin:https://github.com/sshwsfc/xadmin

xadmin部署步骤:

1、把xadmin整个目录拷贝到项目里面

2、需要安装的依赖包:

django~=1.9.0
django-crispy-forms~=1.6.0
django-reversion~=2.0.0
django-formtools==1.0
future==0.15.2
httplib2==0.9.2
six==1.10.0

3、注册xadmin:

把xadmin,crispy_forms,reversion注册到install_apps里面,然后再添加xadmin的url配置就可以了。

import xadmin

urlpatterns = [
    url(r'^xadmin/', xadmin.site.urls),
]

 

4、使用django的命令行工具生成xadmin数据表,然后创建管理后台的超级用户:

分别执行makemigrations和migrate

 创建管理后台的超级用户

 

接着输入email和passwd就可以登陆了。

英文界面不怎么友好,改成中文(我英语不好)

 在settings里修改配置:

#LANGUAGE_CODE = 'en-us'
LANGUAGE_CODE = 'zh-hans'

# TIME_ZONE = 'UTC'
TIME_ZONE = 'Asia/shanghai'

USE_I18N = True

USE_L10N = True

#这里是指定默认时间,如果为True,则写进数据库的时间是utc时间,需要改成False
USE_TZ = False

 很明显,我在monitor app的model里创建的表在这里没显示,因为xadmin的使用,首先需要对model进行注册,才能在后台管理中进行操作。

1、在app里创建py文件:adminx(必须这个名称)

2、导入xadmin和models里的类,格式如下:

 

#!/usr/bin/env python
# _*_ coding:utf-8 _*_
__author__ = "BIGNI"
__date__ = "2017/4/9 21:08"

import xadmin

from django import forms
from xadmin import views
from  monitor import models
# Register your models here.

# from django.contrib.auth.admin import UserAdmin
from django.contrib.auth.forms import ReadOnlyPasswordHashField

class UserCreationForm(forms.ModelForm):
    """A form for creating new users. Includes all the required
    fields, plus a repeated password."""
    password1 = forms.CharField(label='Password', widget=forms.PasswordInput)
    password2 = forms.CharField(label='Password confirmation', widget=forms.PasswordInput)

    class Meta:
        model = models.UserProfile
        fields = ('email','name')

    def clean_password2(self):
        # Check that the two password entries match
        password1 = self.cleaned_data.get("password1")
        password2 = self.cleaned_data.get("password2")
        if password1 and password2 and password1 != password2:
            raise forms.ValidationError("Passwords don't match")
        return password2

    def save(self, commit=True):
        # Save the provided password in hashed format
        user = super(UserCreationForm, self).save(commit=False)
        user.set_password(self.cleaned_data["password1"])
        if commit:
            user.save()
        return user


class UserChangeForm(forms.ModelForm):
    """A form for updating users. Includes all the fields on
    the user, but replaces the password field with admin's
    password hash display field.
    """
    password = ReadOnlyPasswordHashField(label="Password",
        help_text=("Raw passwords are not stored, so there is no way to see "
                    "this user's password, but you can change the password "
                    "using <a href=\"password/\">this form</a>."))

    class Meta:
        model = models.UserProfile
        fields = ('email','password','is_active', 'is_admin')

    def clean_password(self):
        # Regardless of what the user provides, return the initial value.
        # This is done here, rather than on the field, because the
        # field does not have access to the initial value
        return self.initial["password"]


class UserProfileAdmin(object):
    # The forms to add and change user instances
    form = UserChangeForm
    add_form = UserCreationForm

    # The fields to be used in displaying the User model.
    # These override the definitions on the base UserAdmin
    # that reference specific fields on auth.User.
    list_display = ('id','email','is_admin','is_active')
    list_filter = ('is_admin',)
    list_editable = ['is_admin']

    fieldsets = (
        (None, {'fields': ('email','name', 'password')}),
        ('Personal info', {'fields': ('phone','weixin','memo',)}),

        ('用户权限', {'fields': ('is_active','is_staff','is_admin','user_permissions','groups')}),

    )
    # add_fieldsets is not a standard ModelAdmin attribute. UserAdmin
    # overrides get_fieldsets to use this attribute when creating a user.
    add_fieldsets = (
        (None, {
            'classes': ('wide',),
            'fields': ('email',  'password1', 'password2','is_active','is_admin')}
        ),
    )
    search_fields = ('email',)
    ordering = ('email',)
    filter_horizontal = ('user_permissions','groups')






class HostAdmin(object):
    list_display =  ('id','name','ip_addr','status')
    filter_horizontal = ('host_groups','templates')


class HostGroupAdmin(object):
    style_fields = {'templates': 'm2m_transfer'}


class TemplateAdmin(object):
    filter_horizontal = ('services','triggers')
    style_fields = {'services':'m2m_transfer','triggers':'m2m_transfer'}

class ServiceAdmin(object):
    filter_horizontal = ('items',)
    list_display = ('name','interval','plugin_name')
    style_fields = {'items': 'm2m_transfer'}
    #list_select_related = ('items',)


class TriggerExpressionInline(object):
    model = models.TriggerExpression
    #exclude = ('memo',)
    #readonly_fields = ['create_date']


class TriggerAdmin(object):
    list_display = ('name','severity','enabled')
    inlines = [TriggerExpressionInline,]
    #filter_horizontal = ('expressions',)


class TriggerExpressionAdmin(object):
    list_display = ('trigger','service','service_index','specified_index_key','operator_type','data_calc_func','threshold','logic_type')


class BaseSettings(object):
    enable_themes = True
    use_bootswatch = True


class GlobalSettings(object):
    site_title = "大倪的自动化监控系统"
    site_footer = "如有雷同,纯属巧合"
    menu_style = "accordion"


# class ServiceIndexAdmin(object):
#     style_fields = {'idc': 'm2m_transfer'}


xadmin.site.register(models.Host,HostAdmin)
xadmin.site.register(models.HostGroup,HostGroupAdmin)
xadmin.site.register(models.Template,TemplateAdmin)
xadmin.site.register(models.Service,ServiceAdmin)
xadmin.site.register(models.Trigger,TriggerAdmin)
xadmin.site.register(models.TriggerExpression,TriggerExpressionAdmin)
xadmin.site.register(models.ServiceIndex)
xadmin.site.register(models.Action)
xadmin.site.register(models.ActionOperation)
#admin.site.register(models.ActionCondtion,ActionConditionAdmin)
xadmin.site.register(models.Maintenance)
xadmin.site.register(models.UserProfile,UserProfileAdmin)
xadmin.site.register(models.EventLog)

xadmin.site.register(views.BaseAdminView,BaseSettings)
xadmin.site.register(views.CommAdminView,GlobalSettings)
View Code

 

 

 

遇到的问题:

1、

ManyToManyField类型的字段,在xadmin里只显示了一个选项框。解决方法:
在定义的类中,加上这个字段,其中templates对应字段名称,效果如下  style_fields = {'templates': 'm2m_transfer'}

 

py3.6+xadmin的自学网站搭建

xadmin安装  由于安装时需要依赖包并且暂时不支持py3等原因,直接pipinstall的方法很容易就狗带了。  说一下我在网上找到的安装方式,在GitHub上有这个项目的开源代码,并且还有很多个版本可以选择。  克隆一份,clone地... 查看详情

django2.1.5使用xadmin打造适合国人的后台管理系统

...也不太符合我们国人的习惯,因此一个基于bootstrap的后台xadmin诞生了,效果比较适合国内使用。那么今天就来讲怎么用xadmin来作为django的后台。一、准备:1.环境:python3.7+django2.1.52.xadmin下载:https://github.com/sshwsfc/xadmin/tree/django2(... 查看详情

微信小程序需要后台吗?怎么搭建后台

微信小程序需要后台吗?怎么搭建后台小程序前端会,后端不知道怎么搭建微信小程序需要后台,后台就像是网站那样子的管理后台,可以上传产品信息,图片等功能。一般后端程序员把后台弄好,前端程序员就是负责整个小程... 查看详情

(项目)生鲜超市

一、项目介绍  生鲜超市平台,通过Vue+DjangoRestFramework搭建整个网站,通过该项目的学习,可以掌握以下技术点:掌握前端Vue+后端DjangoRestFramework前后端分离技术彻底玩转RestfulAPI的开发流程掌握Sentry,完成线上系统错误日志的... 查看详情

电商网站前台与后台系统架构

...:这些都是本网站的后台系统。下面看下前台系统是如何搭建的:因为现在客户端有pc端和移动端,所以将客户端不直接与数据库连接,而是采用服务端跟数据库连接,每个独立的客户端可以单独调用服务的接口,这样方便部署... 查看详情

django入门5使用xadmin搭建管理后台(代码片段)

环境搭建:pipinstalldjango==1.9.8pipinstallMySQL_python-1.2.5-cp27-none-win_amd64.whlpipinstallfuturerequestsdjango-import-exportsixpipinstall django-simple-captcha==0.4.6pipinstallpillowpipinstallxadmin 然后再次pipuninstallxadmin把django的表都删除,重建的方法:1.在s... 查看详情

django后台管理系统xadmin(代码片段)

目录Djangoxadmin介绍具体安装步骤django2.0.7版本下安装更高级的vueadminDjangoxadmin介绍Django是python的重量级web框架,写得少,做得多,非常适合后端开发,它很大的一个亮点是,自带后台管理模块,但它自带的后台管理有点丑,而Xadmin是基于boot... 查看详情

xadmin插件(代码片段)

目录xadmin介绍:下载:数据库操作:总结:xadmin介绍:django中,自带有admin管理界面,是个非常强大的后台管理界面xadmin是admin的拓展,界面功能比admin更加强大对xadmin进行一些配置,所以不能直接修改pippackage里的模块因此需要做xadmin... 查看详情

django+xadmin打造在线教育系统(代码片段)

基于xadmin的后台管理需要对源码进行修改,将xadmin的源码下载下来https://github.com/sshwsfc/xadmin/tree/django2在项目根目录新建PythonPackage"extra_apps",把源码xadmin文件夹放到extra_apps文件夹下面,此时目录结构如下:将extra_apps加入系统路径#se... 查看详情

安装xadmin后台管理(代码片段)

安装xadmin后台管理下载xadmin源码包https://github.com/sshwsfc/xadmin得到xadmin-master.zip安装xadmin-master.zip注意:需要先加入压缩包,把README.rst用一个同名的空文件替换(Django_login)D:>pipinstallxadmin-master.zipProcessingd:xadmin-mast 查看详情

django(14)xadmin后台介绍(代码片段)

使用步骤1、安装xadmin模块,推荐源码安装;2、在setting.py将xadmin和crispy_forms放进INSTALLED_APPS中;3、同步xadmin自带的表:pythonmanage.pymigrate4、修改url.py:importxadminurlpatterns=[url(r'^xadmin/',xadmin.site.urls),]源码安装Xadmi 查看详情

bootstraptable急速完美搭建后台管理系统

BootstrapTable是基于Bootstrap的jQuery表格插件,通过简单的设置,就可以拥有强大的单选、多选、排序、分页,以及编辑、导出、过滤(扩展)等等的功能:http://bootstrap-table.wenzhixin.net.cn/zh-cn/documentation/现在做的一个app管理以及后台... 查看详情

django后台xadmin如下配置(小结)

django-admin文档:https://xadmin.readthedocs.io/en/latest/index.html目录:  1、xadmin基本配置  2、配置后台显示的模型类   3、后台注册模型类  4、修改后台应用、字段显示的名字   5、修改应用在... 查看详情

django-xadmin+rule对象级权限的实现

...go-admin让我们能够很方便的实现一个管理后台程序。django-xadmin则在拥有admin基本功能的基础上增加了更为丰富的功能、界面也更加漂亮。类似还有django-suit等,本文使用xadmin(功能更丰富);实现需求2:django-admin,以及xadmin都只... 查看详情

python能用来做啥?

...功能强大特点,广泛应用于网站开发、数据分析、爬虫、自动化运维、人工智能、大数据、游戏开发等领取。1、做日常任务,比如下载视频、MP3、自动化操作excel、自动发邮件。2、做网站开发、web应用开发,很多著名的网站像... 查看详情

lampw网站搭建

 环境介绍L:Linux操作系统CentOS7.264位 A:web服务器Apachehttpd-2.4.27 M:数据库mysql-5.7.19 P:后台脚本语言php-7.1.7W:后台管理系统wordpress-4.8Step0:准备工作apache及相关下载:https://www.apache.org/index.html#projects-lis 查看详情

自定义xadmin后台首页(代码片段)

  登陆xadmin后台,首页默认是空白,可以自己添加小组件,xadmin一切都是那么美好,但是添加小组件遇到了个大坑,快整了2个礼拜,最终实现想要的界面。初始的页面如图:  本机后台显示这个页面正常,docker中添加小组... 查看详情

集成xadmin源码到项目的正式姿势

xadmin是强大的,但是为了更好的后期定制开发,可能会修改到xadmin的源码。因此还是推荐将xadmin源码集成到自己的项目中。1、pipinstallxadmin安装xadmin的模块,系统会自动安装相关依赖。2、在settings里面加入apps‘xadmin‘,‘crispy_form... 查看详情