Django之后台管理二
前面讲到admin界面用户的注册以及修改,如果我们注册的用户密码忘记了该怎么办呢
在终端输入如下的命令进行重置
D:\django_test2>python manage.py shell
Python 2.7.11 (v2.7.11:6d1b6a68f775, Dec 5 2015, 20:32:19) [MSC v.1500 32 bit (Intel)]
Type "copyright", "credits" or "license" for more information.
IPython 5.3.0 -- An enhanced Interactive Python.
? -> Introduction and overview of IPython's features.
%quickref -> Quick reference.
help -> Python's own help system.
object? -> Details about 'object', use 'object??' for extra details.
In [2]: from django.contrib.auth.models import User
In [3]: user = User.objects.get(username='zhf')
(0.001) SELECT "auth_user"."id", "auth_user"."password", "auth_user"."last_login", "auth_user"."is_superuser", "auth_user"."username", "auth_user"."first_name", "auth_user"."last_name", "auth_user"."email", "auth_
user"."is_staff", "auth_user"."is_active", "auth_user"."date_joined" FROM "auth_user" WHERE "auth_user"."username" = 'zhf'; args=('zhf',)
In [4]: user.set_password('xxxxx')
In [5]: user.save()
(0.000) BEGIN; args=None
(0.001) UPDATE "auth_user" SET "password" = 'pbkdf2_sha256$30000$ztylCxamAKb3$upNib9+1EAYRkMGwKESIsy7m6VIzsef0ioHsJYer3wQ=', "last_login" = '2017-12-10 13:53:11.655000', "is_superuser" = 1, "username" = 'zhf', "fi
rst_name" = '', "last_name" = '', "email" = 'maple412@163.com', "is_staff" = 1, "is_active" = 1, "date_joined" = '2017-12-10 13:34:59.874000' WHERE "auth_user"."id" = 1; args=(u'pbkdf2_sha256$30000$ztylCxamAKb3$up
Nib9+1EAYRkMGwKESIsy7m6VIzsef0ioHsJYer3wQ=', u'2017-12-10 13:53:11.655000', True, u'zhf', u'', u'', u'maple412@163.com', True, True, u'2017-12-10 13:34:59.874000', 1)
下面进入关键部分,前面只有用户的信息,如何来监控我们自己定义的模块呢。比如我们在models.py中定义的那些模型如何在后台显示出来呢。我们先看下Django的文件结构,可以看到有一个admin.py的文件。这里就是我们对模型进行注册的地方。
我们首先对这些模块进行注册,代码如下
我们再来看下管理界面:可以看到已经增如如下的界面,里面有我们注册的各个模块
那么这些模块的信息是否和我们之前已经创建过的一样呢。我们拿book来举例,点击Book可以看到如下的用户。
点击其中的书名称,即可以进去进行修改
我们可以通过管理界面的增加按钮添加对应的模块
如下图所示:
这些选项和我们模板中的定义的都一样。每一个都是必填项。如果我们添加的时候有一项没有添加,则会报错,如下,提示Address字段是必填项
那么我们怎么能修改某些项为非必填的呢。这需要在模板中修改定义。在address的具体定义中增加blank=True的描述,那么这项就变成了非必填项
可以看到address的颜色变成了灰色。
同样的使用方法还有verbose_name字段,这个设置可以给这些项添加一个别名。如下address将会显示为detail_address
address=models.CharField(max_length=40,blank=True,verbose_name='detail_address')
之前新增了一个author。点击查看的时候除了能看到名字意外,其他如名字,邮件,和地址等信息都看不到。
如果我们想显示出的信息,需要修改代码如下。在admin.py中修改如下:
我们新增了一个显示模板,只定义了一项,就是显示名称的元组。用于列表显示。然后在register中新增了AuthorAdmin,这个可以理解为将AuthorAdmin模块注册到Author中去。
我们所有对于模板的显示和自定义操作都可以在这里面进行重写
class AuthorAdmin(admin.ModelAdmin):
list_display = ('first_name','last_name','email','age')
list_editable = ('email','age')
admin.site.register(Author,AuthorAdmin)
从下面的解释中可以看到,如果第二个参数没有设置,那么模板将会继续使用第一个参数的模板
我们现在来看下界面:可以看到增加了各个具体字段的显示。并且email和age可以在线编辑修改。不用点击进入具体模块进行修改。
增加list_filter和serach_fields的定义。并会出现对应的过滤器框
list_filter=('age','email')
search_fields = ('age','email')
在输入框中输入对应的搜索字段,便可以得到对应的搜索结果
我们再继续看下动作的定义:在默认的动作项中,只有删除的动作。如果我们想有更多自定义的动作该如何操作呢
在AuthorAdmin中添加action的描述。Actions里面是具体的动作函数,在这里是save_excel
然后自定义的save_excel函数。并且携带request以及queryset的参数。其中request可以访问的参数,可以用来区别用户,queryset是author的查询集合。save_excel.short_description用来命名在动作显示的名字。
class AuthorAdmin(admin.ModelAdmin):
list_display = ('first_name','last_name','email','age')
list_editable = ('email','age')
list_filter=('age','email')
search_fields = ('age','email')
actions = [u'save_excel']
def save_excel(self,request,queryset):
pass
save_excel.short_description = u'下载选中的数据'
这样在动作中就有了我们自定义的action。
在后台的访问中,有多个用户都会登录进来,那么我们想针对不同的用户进行权限隔离,该如何操作呢。这里就要用到重写changelist_view
首先我们增加一个非super权限的账户:
并且设置所有模型的添加,修改,删除权限
添加后可以看到2个用户。
在AuthorAdmin中定义changelist_view函数,通过request.user.is_superuser来判断是否为超级用户,并且对超级用户和非超级用户的显示和编辑权限进行区分设置
def changelist_view(self, request, extra_context=None):
if request.user.is_superuser:
self.list_display = ('first_name','last_name','email','age')
self.list_editable = ('email','age')
self.list_filter=('age','email')
self.search_fields = ('age','email')
else:
self.list_display = ('email','age')
self.list_filter = ('email','age')
return super(AuthorAdmin, self).changelist_view(request, extra_context=None)
再次以zhf1的账户登录,发现其中的显示页面以及可编辑页面都已经和超级用户不同。
我们来看另外一个模板,Book, 其中authors的定义是manytomanyFiled。这是什么意思呢,通俗理解就是多对多。就比如一本书的作者有多个不知一个的意思。
class Book(models.Model):
title = models.CharField(max_length=100)
authors = models.ManyToManyField(Author)
publisher = models.ForeignKey(Publisher)
publication_date = models.DateField()
def __unicode__(self):
return self.name
如下在Authors的界面中可以看到2个之前新增的用户
另外注意Publisher, 在模板中的定义是ForeignKey也就是数据库中的外键。我们添加的时候会自动跳到Publisher的界面
可以看出django的后天可以方便我们对数据进行各种高效的管理,相比flask,django提供了各种各样的模块,更加方便我们对数据的处理。更多admin的用法请参考官方的介绍文档