修改settings.pyhtml
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 这时候会提示你输入建立超级用户用于登陆管理后台。python
修改urls.pymysql
如今能够配置admin的url配置:直接取消注释便可。以下图sql
这就是Django管理界面,能够随意操做..django
依然用前面用到的例子products app 具体看上一章 Product,Company这两个模型。vim
在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)
效果以下图:

当服务启动时,Django从`` url.py`` 引导URLconf,而后执行`` admin.autodiscover()`` 语句。 这个函数遍历INSTALLED_APPS配置,而且寻找相关的 admin.py文件。 若是在指定的app目录下找到admin.py,它就执行其中的代码。session
在`` products`` 应用程序目录下的`` admin.py`` 文件中,每次调用`` admin.site.register()`` 都将那个模块注册到管理工具中。 管理工具只为那些明确注册了的模块显示一个编辑/修改的界面。app
应用程序`` 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/