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

Posted 爬行的龟

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自动化监控系统 搭建xadmin做网站后台相关的知识,希望对你有一定的参考价值。

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\'}

 

以上是关于自动化监控系统 搭建xadmin做网站后台的主要内容,如果未能解决你的问题,请参考以下文章

在线教育平台:Xadmin快速搭建后台管理系统

利用xadmin快速搭建后台管理系统

Django打造在线教育平台_day_3: 搭建后台管理系统Xadmin

Django打造在线教育平台_day_3: 搭建后台管理系统Xadmin之其他app的数据表注册

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

django入门5使用xadmin搭建管理后台