您的位置:首页 > 编程语言 > Go语言

Django xadmin的使用 (一)

2017-06-05 16:08 375 查看

Django xadmin的使用

xadmin是django的一个第三方的管理后台实现,它的功能比自带的admin功能更加强大。
xadmin项目在github上的地址为:https://github.com/sshwsfc/xadmin
xadmin相关文档可以在这里查看:https://xadmin.readthedocs.io/en/latest/index.html

这里简要总结下自己集成xadmin的方法,我使用的是django1.10和python3.52,xadmin是0.60。

1. 从上面github地址下载 xadmin(网上有说直接pip安装的,但我这里安装失败,可能是python3的缘故吧)。



并根据requirements.txt 安装所需要的模块。

2.创建一个新的project,并将上面目录中的xadmin目录拷贝到新的project下。



3.在项目中添加xadmin配置

1)settings.py文件
INSTALLED_APPS中添加xadmin的安装,文档网站上是这样写的:

INSTALLED_APPS = (
...
'xadmin',
'crispy_forms',
'reversion',
...
)


2)urls.py文件
urls里面要添加xadmin的匹配,示例如下:

from django.conf.urls import patterns, include, url
from xadmin.plugins import xversion
import xadmin

#version模块自动注册需要版本控制的 Model
xversion.register_models()

xadmin.autodiscover()

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


4.创建一个app,写models,将app注册。

python manage.py startapp hys_datamanagement



models:

from django.db import models

class UserInfo(models.Model):
"""用户表"""
user_name = models.CharField(max_length=20, unique=True, verbose_name=u"负责人")         # 负责人
user_email = models.EmailField(null=True, blank=True, verbose_name=u"邮箱")     # 邮箱
user_mobile = models.BigIntegerField(verbose_name=u"电话")                 # 电话

class Meta:
db_table = 'user_info'
verbose_name = '用户表'
verbose_name_plural = "用户表"

def __str__(self):
return self.user_name


    

然后再注册app:



5.修改数据库连接信息,配置 Django 以便与 Oracle 数据库交互。

  由于本次示例使用oracle数据库现有数据,所以配置连接oracle

首先,您必须安装对应版本的cx_Oracle。 下载地址:https://pypi.python.org/pypi/cx_Oracle
打开 settings.py 文件,并根据您的数据库编辑与数据库相关的设置。例如,您可能按如下方式编辑它们:

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.oracle',
'NAME': 'orcl',
'USER': 'hys_datamanagement',
'PASSWORD': 'hys_datamanagement',
'HOST': '192.168.168.224',
'PORT': '1521',
}
}


  注:创建数据库用户的语句:

create user hys_datamanagement identified by hys_datamanagement;
grant connect,resource to hys_datamanagement;

然后创建数据库表:

python manage.py makemigrations

python manage.py migrate

效果:



6.配置adminx.py文件

django自带的admin模块使用的是admin.py文件,xadmin模块的文件名则叫adminx.py。

admin模块在配置时使用的参数是admin.ModelAdmin,xadmin则使用object即可。然后替换admin.site.register为xadmin.site.register。如下:



# from django.contrib import admin
from .models import UserInfo
import xadmin

class UserInfoAdmin(object):
list_display = ('user_name', 'user_email', 'user_mobile')

xadmin.site.register(UserInfo, UserInfoAdmin)


  

然后就可以启动服务,看看效果了:

访问 http://127.0.0.1:8000/xadmin/


通过命令 python manage.py createsuperuser 创建超级用户。



登录后:



至此,基本配置就完成了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: