• python Django 学习笔记(五)—— Django admin自动管理界面


    1,激活管理界面

    • 修改settings.py

    MIDDLEWARE_CLASSES = (
        'django.middleware.common.CommonMiddleware',
        'django.contrib.sessions.middleware.SessionMiddleware',
        'django.middleware.csrf.CsrfViewMiddleware',
        'django.contrib.auth.middleware.AuthenticationMiddleware',
        'django.contrib.messages.middleware.MessageMiddleware',
        # Uncomment the next line for simple clickjacking protection:
         'django.middleware.clickjacking.XFrameOptionsMiddleware',
         'django.middleware.locale.LocaleMiddleware',
    )
    
    
    INSTALLED_APPS = (
        'django.contrib.auth',
        'django.contrib.contenttypes',
        'django.contrib.sessions',
        'django.contrib.sites',
        'django.contrib.messages',
        'django.contrib.staticfiles',
        # Uncomment the next line to enable the admin:
         'django.contrib.admin',
        # Uncomment the next line to enable admin documentation:
         'django.contrib.admindocs',
        'DjangoMysqlSite.products', #这个是我上章建立的app,可参考前面
    )

       修改完后到项目目录执行 python manage.py syncdb 这时候会提示你输入创建超级用户用于登录管理后台。

    • 修改urls.py

       现在可以配置admin的url配置:直接取消注释即可。如下图

     

    •  python manage.py runserver 开启开发服务器,http://127.0.0.1:8000/admin 测试。

    这就是Django管理界面,可以随意操作..

    2,注册自己的模型到管理界面

    依然用前面用到的例子products app 具体看上一章 Product,Company这两个模型。

    在products目录下新建admin.py,代码如下:

    admin.site.register(Company,CompanyAdmin)
    admin.site.register(Product,ProductAdmin)
    以上两句即可注册到管理后台,下面是添加了一些附加功能的一些代码,当然自己可以自由定义。
    #vim: set fileencoding=utf-8 :
    
    from django.contrib import admin
    from DjangoMysqlSite.products.models import Company,Product
    
    #自定义显示列
    class CompanyAdmin(admin.ModelAdmin):
        list_display = ('full_name','address','tel')
        search_fields = ('full_name',) 
    
    class ProductAdmin(admin.ModelAdmin):
        list_display = ('product_name','price','stock','create_date')#自定义显示列
        search_fields = ('product_name','price')#搜索字段
        list_filter = ('create_date',) #右边小窗过滤器
        date_hierarchy = 'create_date' #对一个日期型字段进行层次划分
        ordering = ('-create_date',)#列表排序字段
        fields  = ('product_name','stock','price','create_date',)#定义表单字段的顺序,默认安装模型中定义顺序
    
    admin.site.register(Company,CompanyAdmin)
    admin.site.register(Product,ProductAdmin)
    效果如下图:

     3,Admin是如何工作的

    当服务启动时,Django从`` url.py`` 引导URLconf,然后执行`` admin.autodiscover()`` 语句。 这个函数遍历INSTALLED_APPS配置,并且寻找相关的 admin.py文件。 如果在指定的app目录下找到admin.py,它就执行其中的代码。

    在`` products`` 应用程序目录下的`` admin.py`` 文件中,每次调用`` admin.site.register()`` 都将那个模块注册到管理工具中。 管理工具只为那些明确注册了的模块显示一个编辑/修改的界面。

    应用程序`` django.contrib.auth`` 包含自身的`` admin.py`` ,所以Users和Groups能在管理工具中自动显示。 其它的django.contrib应用程序,如django.contrib.redirects,其它从网上下在的第三方Django应用程序一样,都会自行添加到管理工具。

    综上所述,管理工具其实就是一个Django应用程序,包含自己的模块、模板、视图和URLpatterns。 你要像添加自己的视图一样,把它添加到URLconf里面。 你可以在Django基本代码中的django/contrib/admin 目录下,检查它的模板、视图和URLpatterns,但你不要尝试直接修改其中的任何代码,因为里面有很多地方可以让你自定义管理工具的工作方式。 (如果你确实想浏览Django管理工具的代码,请谨记它在读取关于模块的元数据过程中做了些不简单的工作,因此最好花些时间阅读和理解那些代码。)

    最后说明一点这个管理界面不一定适合你要做的项目应用中,仅作为理解学习Django。当然对于简单的一些资讯新闻类可以直接采用这个管理后台,更多的这方面的可以访问https://docs.djangoproject.com/en/dev/ref/contrib/admin/

  • 相关阅读:
    preventDefault()、stopPropagation()、return false 之间的区别
    angular $q服务的用法
    Introduction
    软件工程第一次作业
    整除光棍(天梯)
    遍历数据文件目录music中的所有歌单,提取歌曲名称以及对应的标签,并进行统计。统计各个标签的歌曲数目,并在每个标签下找出出现次数最多的3首歌曲,写入到excel表格中:
    Python中字符串的format
    Kafka设计原理总结
    Dubbo源码分析
    浅谈HTTPS传输过程
  • 原文地址:https://www.cnblogs.com/wendoudou/p/3415552.html
Copyright © 2020-2023  润新知