Django教程-admin模块

Django教程-admin模块

有个网站开发经验的同学应该都知道,网站都会有个后台管理界面,这个界面是只有管理员权限的用户才能进入管理网站内容。比如个人博客,CMS都会有这样的管理后台。管理后台的页面通常都是简单重复的页面,他们可重用性很高,所以作为一个大而全的框架,django为广大开发者提供了这样一个模块,让你无需编写很多的代码,就可以写出实用美观的后台管理页面,大大提高了中小型网站的开发效率。今天我们就先来了解下如何使用admin模块。

初识admin

首先我们新建一个site和app。
接下来我们修改settings.py的INSTALLED_APPS如下:

INSTALLED_APPS = (
    'django.contrib.admin',    #加入admin模块,通常新建工程就有,没有的话需要自己添加
    'django.contrib.auth',       #权限验证,同样需要
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app',  #your app
)

然后在urls.py文件里添加admin模块拦截,代码如下(注意django1.8前后版本区别,这里是1.8之前版本的写法)

from django.conf.urls import patterns, include, url
from django.contrib import admin

from app.views import params_test, params_test_reg, params_post, form_view, createstudent

urlpatterns = patterns('',
    # Examples:
    # url(r'^$', 'PostParams.views.home', name='home'),
    # url(r'^blog/', include('blog.urls')),

    url(r'^admin/', include(admin.site.urls)),    #admin模块url拦截
    url(r'^params_test/$',params_test),
    url(r'^params_test_reg/str(?P\w+)page(?P\d+)/$',params_test_reg),
    url(r'^post/$',params_post),
    url(r'^form/$',form_view),
    url(r'^createstudent/$', createstudent),
)

做完这些操作后,我们需要更新同步数据库信息,将admin模块的模型导入数据库。(前面已经介绍过,本节不做过多介绍)
既然是admin管理模块,我们还需要个默认管理员账号,使用以下命令创建
python manage.py createsuperuser
按照提示即可完成操作,管理员账号创建完成后,我们就可以启动服务器
python manage.py runserver
然后我们打开浏览器,输入127.0.0.1:8000/admin就可以看见后台登陆页面

image.png

输入用户名密码登陆后就可以看到如下界面
只有

可以看到这时候管理后台只有默认的groups和users选项,没有我们自己的student和course管理,不要着急,接下来就介绍如何在admin模块添加模型管理。

admin

我们在app里面新增两个model,代码如下

from django.db import models

# Create your models here.
class Label(models.Model):
    title=models.CharField(max_length=20,verbose_name='label name')
class Article(models.Model):
    title=models.CharField(max_length=20,verbose_name='title')
    content=models.CharField(max_length=10,verbose_name='content')
    labels=models.ManyToManyField(Label,verbose_name='labels',blank=True,null=True)

然后同步数据库,这些前面已经介绍过,本节不做过多介绍。
后台管理的代码django建议放在admin.py(放在其他位置也可以),对于admin模块的代码与其说是开发,不如说是配置,因为django已经为我们封装好了很多模块和功能,我们只需要简单地配置下就能实现很多功能。
话不多说,我们添加上面两个model的管理界面,代码如下

from django.contrib import admin

# Register your models here.
from app.models import Article, Label


class ArticleAdmin(admin.ModelAdmin):
    pass
class LabelAdmin(admin.ModelAdmin):
    pass
admin.site.register(Article,ArticleAdmin)
admin.site.register(Label,LabelAdmin)

代码非常简单,我们只需要继承ModelAdmin,然后将model和对应的ModelAdmin注册到admin中就可以。
我们重新启动服务器,登入后台管理界面,就可以看到后台管理界面已经出现我们刚刚新加的两个model


image.png

我们点击Labels里面进去看看


image.png

暂时是空的,我们新增一个看看


image.png

保存后返回到列表页面



就可以看到现在列表中已经存在一个我们新增的label,当然这时候显示还是有问题的,但是基本的后台管理功能已经实现了。
可以发现,django后台模块功能非常强大,我们甚至没有编写任何代码,就拥有一个可以使用的后台管理模块。当然现有的后台管理页面还是简陋功能不完善的,接下来的章节我将会继续和大家探讨如何个性化后台管理页面以及实现更多的功能,从而使其满足大家的开发需求。

最近参加支付宝小程序比赛需要访问量,麻烦各位看官有空复制下面的话打开支付宝,搜索栏粘贴,在此多谢各位支持了

#JvCmawp74I1#长按复制此消息,打开支付宝搜索,体验南京疫情地图小程序

你可能感兴趣的:(Django教程-admin模块)