Django Admin后台管理模块的使用

Admin后台管理模块的使用

Django的管理员模块是Django的标准库django.contrib的一部分。这个包还包括其它一些实用的模块:

django.contrib.auth

django.contrib.sessions

django.contrib.comments

激活admin模块的方法是:

1. 在INSTALLED_APPS设置文件中,加入‘django.contrib.admin‘

2. 再添加

‘django.contrib.auth‘,

‘django.contrib.contenttypes‘

‘django.contrib.sessions‘

因为admin模块依赖

3. 在MIDDLEWARE_CLASSES属性中添加

‘django.middleware.common.CommonMiddleware‘,

‘django.contrib.sessions.middleware.SessionMiddleware‘

‘django.contrib.auth.middleware.AuthenticationMiddleware‘.

也是因为依赖

4. 运行python manage.py syncdb,用于创建为admin等模块创建新的数据库表。

因为apps中有auth模块,会要求你创建一个超级用户。如果你取消这步,

也可以运行python manage.py createsuperuser。当且仅当,你安装了auth模块。

5. 在urls.py中设置admin映射

# Include these import statements...

from django.contrib import admin

admin.autodiscover()

# And include this URLpattern...

urlpatterns = patterns(‘‘,

# ...

(r‘^admin/‘, include(admin.site.urls)),

# ...

)

6. 记住在你的模块中增添admin模板文件,可以复制django自带模板,注意在模块路径中添加

admin文件夹。

D:\Python27\Lib\site-packages\django\contrib\admin\templates\admin\base_site.html

7. 运行python manage.py runserver,网址中输入http://localhost:8000/admin/

8. admin界面默认是显示英语,如果要显示你需要的语言:

在MIDDLEWARE_CLASSES属性中添加‘django.middleware.locale.LocaleMiddleware‘,并确保它

排列在SessionMiddleware后面。重新刷新admin页面

在admin页面中管理models模块:

1. 需要在你的app下创建一个admin.py文件,并对你的model类进行注册

from django.contrib import admin

from mysite.books.models import Publisher, Author, Book

admin.site.register(Publisher)

admin.site.register(Author)

admin.site.register(Book)

2. 当你在project文件夹中添加新的文件时,需要重启server才能生效。

3. 如果想要你的admin界面中的添加数据功能生效,需要在MIDDLEWARE_CLASSES属性中添加

‘django.contrib.messages.middleware.MessageMiddleware‘,

自定义admin模块的显示

1. 取消在添加数据时,每一个字段都需要输入的限制

在model类中做相应的修改就可以了:

class Author(models.Model):

first_name = models.CharField(max_length=30)

last_name = models.CharField(max_length=40)

email = models.EmailField(blank=True)

只需要在字段声明中,设置blank=True,默认是False

关于NULL与空字符串的区别

在数据库操作中,NULL和空字符串""是两上不同的概念,有些数据库类型即能接受NULL值,又能接受

空字符串类型,例如,varchar类型,到底什么时候使用这两者,久而久之,容易造成数据的不一致,为

了避免这样的情况,Django默认是把blank=True这样的字段,统一做为空字符串插入到数据库中。同

时,在创建数据表的时候,所有字段统一默认使用NOT NULL。

但是,当遇到时间,日期类型的时候,空字符串反而会出错。这个时候,又需要使用NULL,只需要在model

字段声明中加入:

publication_date = models.DateField(blank=True, null=True)

一旦你加入null=True声明,这样就相当于改变了数据库表结构,类似SQL语句中的

alter table books_book modify publication_date date null;

然而之前说过,Django的python manage.py syncdb只能用表创建新表,不能更改表结构,所以这时你需要

在数据库中进行更新表结构操作。

在admin界面的编辑页面中,字段名字的显示是根据model类中的变量名来显示的,大写第一个字母,把下划线改

成空格显示出来。自定义显示可以使用verbose_name参数

email = models.EmailField(blank=True, verbose_name=‘e-mail‘)

使用ModelAdmin来管理model在admin页面中的显示

  • 自定义chanle list界面

ModelAdmin类似界面管理类,可以定义不同的显示细节。用法如下:

 

from django.contrib import admin
from mysite.books.models import Publisher, Author, Book

class AuthorAdmin(admin.ModelAdmin):
    list_display = (‘first_name‘, ‘last_name‘, ‘email‘)#把字段信息全部显示出来

search_fields = (‘first_name‘, ‘last_name‘) #添加search bar,在指定的字段中search

class BookAdmin(admin.ModelAdmin):

list_display = (‘title‘, ‘publisher‘, ‘publication_date‘)

list_filter = (‘publication_date‘,)#页面右边会出现相应的过滤器选项

date_hierarchy = ‘publication_date‘ #只接受日期类型的字段名

ordering = (‘-publication_date‘,) #排序

admin.site.register(Publisher)
admin.site.register(Author, AuthorAdmin)
admin.site.register(Book, BookAdmin)

  • 自定义edit form界面

fields = (‘title‘, ‘publisher‘, ‘authors‘, ‘publication_date‘) #edit界面就按这个顺序显示

还可以定义可编辑的字段

fields = (‘title‘, ‘authors‘, ‘publisher‘)

这样Django会自动给publication_data设置为null,记得null=True设置为null值

当遇到many-to-many的多选的字段类型时,Django自动提供上图中的选择方式,不过还可以

选择用其它方式来进行多选,这种方式更加直观,不过只能作用于many-to-many的多选字段,

不能应用于foreignkey字段。

filter_horizontal = (‘authors‘,)

当然也有filter_vertical...

对于ForeighKey字段,也有相应的设置,用来输入字段的ID,点击边上的

放大镜图标,也会弹出选择框

raw_id_fields = (‘publisher‘,)

关于用户,组,权限

Django提供了很详细的权限设置方案。包括对每一张表的控制权限。

时间: 2024-10-04 16:00:12

Django Admin后台管理模块的使用的相关文章

django admin后台管理数据复选框的使用

1.admin后台管理数据表,首先需要在admin.py中注册models # -*- coding: utf-8 -*- from __future__ import unicode_literals from django.contrib import admin from .models import test_table from .models import person ''' class ngo_base_info_admin(admin.ModelAdmin): list_dis

Django Admin后台管理

1.使用 (1)本地化,语言和时区本地化 (2)创建超级管理员 (3)注册模型类:定义显示的内容 (a)models.py定义 (b)效果 (c)admin.py注册 (4)自定义管理页面:显示方式,固件 (a)自定义模型管理类 效果: (b)注册模型类的时候给register函数添加第二个参数,就是自定义模型管理类的名字 返回表的标题 (5)关联对象 无法直接访问关联对象的属性或方法,可以在模型类中封装方法,访问关联对象的成员. (a)例如:显示父级地区,如果没有父级就返回空 效果: (6)分

Linux下开发python django程序(设置admin后台管理模块)

1.新建项目和项目下APP django-admin startproject csvt03 django-admin startapp app1 2.修改settings.py文件 设置默认安装APP INSTALLED_APPS = ( 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.sites', 'django.contrib.messages

Django Admin后台管理功能使用(学习版)

一.前言: 在创建完Django项目后,每个app下,都会有一个urls.py文件,里边会有如下几行: from django.contrib import admin urlpatterns = [    url(r'^admin/',admin.site.urls), ] 上边看到导入的admin模块 二.主要功能: 功能1:提供数据库管理功能 基于admin模块,可以实现类似数据库客户端的功能,对数据进行增删改查 功能2:二次开发 基于该模块的数据管理功能,可以二次定制一些实用的功能. 三

Python菜鸟之路:Django Admin后台管理功能使用

前言 用过Django框架的童鞋肯定都知道,在创建完Django项目后,每个app下,都会有一个urls.py文件,里边会有如下几行: from django.contrib import admin urlpatterns = [ url(r'^admin/', admin.site.urls), ] 上边看到导入的admin模块,就是本节所要说的主要内容 主要功能 功能1:提供数据库管理功能 基于admin模块,可以实现类似数据库客户端的功能,对数据进行增删改查 功能2:二次开发 基于该模块

自定义路由组件,Django的admin后台管理,DRF的三大认证,jwt认证

目录 一.自定义路由组件 1. 为什么要自定义路由组件 2. 自定义路由组件实例 二.Django的admin后台管理 三.DRF的三大认证组件概括 1. 认证组件 2. 权限组件 3. 频率组件 四.Django中的用户权限管理 五.jwt认证 1. jwt认证和普通session认证的区别 2. jwt认证介绍 (1)jwt的原理 (2)jwt三部分的内容 3. jwt的签发算法 (1)第一步:头部算法 (2)第二步:载荷部分的算法 (3)第三步:签名部分的算法 (4)第四步:连接生成tok

django-17.admin后台管理

前言 通常一个网站开发,需要有个后台管理功能,比如用后台管理发布文章,添加用户之类的操作.django的admin后台管理主要可以实现以下功能 基于admin模块,可以实现类似数据库客户端的功能,对数据进行增删改查 于该模块的数据管理功能,可以二次定制一些实用的功能. settings.py配置 在INSTALLED_APPS中,默认已经添加相关模块, 可以不用管 django.contrib.admin 管理站点 django.contrib.auth 认证系统 django.contrib.

django-添加文章&admin后台管理

通过表单形式与后端交互: 前端表单: add.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>添加文章</title> </head> <body> <form action="/add/" method="post" enc

Django Admin Cookbook-14如何在Django Admin后台移除“删除所选”操作

14.如何在Django Admin后台移除"删除所选"操作? 默认情况下,Django Admin后台的listview模型列表页,会有一个Delete Selected删除所选操作.假设你需要再从Hero管理模型中移除该删除操作. ModelAdmin.get_actions方法可以返回所有的操作方法.通过覆盖此方法,移除其中delete_selected方法,便可可以从下拉列表中删除它.将Hero管理模型的代码修改如下: def get_actions(self, request