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的用法请参考官方的介绍文档

 

 

 

 

 

 


 


 

posted @ 2017-12-24 14:37  red_leaf_412  阅读(2317)  评论(1编辑  收藏  举报