django-17.admin后台管理

 

前言

通常一个网站开发,需要有个后台管理功能,比如用后台管理发布文章,添加用户之类的操作。django的admin后台管理主要可以实现以下功能

  • 基于admin模块,可以实现类似数据库客户端的功能,对数据进行增删改查
  • 于该模块的数据管理功能,可以二次定制一些实用的功能。

settings.py配置

在INSTALLED_APPS中,默认已经添加相关模块, 可以不用管

  • django.contrib.admin 管理站点
  • django.contrib.auth 认证系统
  • django.contrib.contenttypes 用于内容类型的框架
  • django.contrib.sessions 会话框架
  • django.contrib.messages 消息框架
  • django.contrib.staticfiles 管理静态文件框架
# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',          # 管理站点
    'django.contrib.auth', # 认证系统 'django.contrib.contenttypes', # 用于内容类型的框架 'django.contrib.sessions', # 会话框架 'django.contrib.messages', # 消息框架 'django.contrib.staticfiles', # 管理静态文件框架 'hello', # 应用app ] 

urls.py创建

urls.py创建admin后台的访问路径

from django.contrib import admin
from django.conf.urls import url


urlpatterns = [
    url(r'^admin/', admin.site.urls), .... ]

创建admin管理用户

django默认是没管理员用户的,需要执行指令,手动创建一个admin账号

python manage.py createsuperuser

如下创建的管理员用户名admin, 配置邮箱 [email protected],密码设置123456

D:\web_djo\helloworld>python manage.py createsuperuser
Username (leave blank to use 'admin'): admin
Email address: 283340479@qq.com Password: Password (again): This password is too short. It must contain at least 8 characters. This password is too common. This password is entirely numeric. Bypass password validation and create user anyway? [y/N]: y Superuser created successfully.

models.py文件创建表

在app 的models.py文件中创建表信息,即表类,相关操作参考前面的一篇https://www.cnblogs.com/yoyoketang/p/10331049.html

# models.py

from django.db import models

# Create your models here.
 
# 我们新建了一个Person类,继承自models.Model, class Person(models.Model): name = models.CharField(max_length=30) age = models.IntegerField() # 新增一张用户表,表名为user 字段user_name, psw ,mail 都是字符串类型 class User(models.Model): user_name = models.CharField(max_length=30, primary_key=True) # 设置为主键 psw = models.CharField(max_length=30) mail = models.CharField(max_length=30)

创建表之后需执行

python manage.py makemigrations
python manage.py migrate

访问admin后台

在浏览器上访问后台http://localhost:8000/admin/,用户名和密码就是刚才新建的admin 123456

访问后查看到的页面

刚才新建的User和Person并没有显示在这里,需要在admin.py中注册表

admin.py注册表

如果想让新建的表,显示到后台管理里面,需要在admin.py中添加注册信息,如下在admin.py中注册2个表信息

# admin.py
from django.contrib import admin from hello import models # Register your models here. admin.site.register(models.User) admin.site.register(models.Person)

接着刷新下页面,就能看的刚才注册的2个表信息了

显示优化

打开一张表查看详细信息,显示的是User object这种内容,如果想显示具体的标名称,可以用__str__方法,相关语法参考https://www.cnblogs.com/yoyoketang/p/10342017.html

于是可以优化models.py里面的代码,加上一个def __str__(self):

class Person(models.Model):
    '''用户信息''' name = models.CharField(max_length=30) age = models.IntegerField() def __str__(self): return self.__doc__ + ":name>" + self.name class User(models.Model): '''注册表''' user_name = models.CharField(max_length=30, primary_key=True) psw = models.CharField(max_length=30) mail = models.CharField(max_length=30) def __str__(self): return self.__doc__ + ":user_name->" + self.user_name 

刷新amdin后台页面后显示

选个记录点进去就可以对相应的数据增删改查了

 

前言

通常一个网站开发,需要有个后台管理功能,比如用后台管理发布文章,添加用户之类的操作。django的admin后台管理主要可以实现以下功能

  • 基于admin模块,可以实现类似数据库客户端的功能,对数据进行增删改查
  • 于该模块的数据管理功能,可以二次定制一些实用的功能。

settings.py配置

在INSTALLED_APPS中,默认已经添加相关模块, 可以不用管

  • django.contrib.admin 管理站点
  • django.contrib.auth 认证系统
  • django.contrib.contenttypes 用于内容类型的框架
  • django.contrib.sessions 会话框架
  • django.contrib.messages 消息框架
  • django.contrib.staticfiles 管理静态文件框架
# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',          # 管理站点
    'django.contrib.auth', # 认证系统 'django.contrib.contenttypes', # 用于内容类型的框架 'django.contrib.sessions', # 会话框架 'django.contrib.messages', # 消息框架 'django.contrib.staticfiles', # 管理静态文件框架 'hello', # 应用app ] 

urls.py创建

urls.py创建admin后台的访问路径

from django.contrib import admin
from django.conf.urls import url


urlpatterns = [
    url(r'^admin/', admin.site.urls), .... ]

创建admin管理用户

django默认是没管理员用户的,需要执行指令,手动创建一个admin账号

python manage.py createsuperuser

如下创建的管理员用户名admin, 配置邮箱 [email protected],密码设置123456

D:\web_djo\helloworld>python manage.py createsuperuser
Username (leave blank to use 'admin'): admin
Email address: 283340479@qq.com Password: Password (again): This password is too short. It must contain at least 8 characters. This password is too common. This password is entirely numeric. Bypass password validation and create user anyway? [y/N]: y Superuser created successfully.

models.py文件创建表

在app 的models.py文件中创建表信息,即表类,相关操作参考前面的一篇https://www.cnblogs.com/yoyoketang/p/10331049.html

# models.py

from django.db import models

# Create your models here.
 
# 我们新建了一个Person类,继承自models.Model, class Person(models.Model): name = models.CharField(max_length=30) age = models.IntegerField() # 新增一张用户表,表名为user 字段user_name, psw ,mail 都是字符串类型 class User(models.Model): user_name = models.CharField(max_length=30, primary_key=True) # 设置为主键 psw = models.CharField(max_length=30) mail = models.CharField(max_length=30)

创建表之后需执行

python manage.py makemigrations
python manage.py migrate

访问admin后台

在浏览器上访问后台http://localhost:8000/admin/,用户名和密码就是刚才新建的admin 123456

访问后查看到的页面

刚才新建的User和Person并没有显示在这里,需要在admin.py中注册表

admin.py注册表

如果想让新建的表,显示到后台管理里面,需要在admin.py中添加注册信息,如下在admin.py中注册2个表信息

# admin.py
from django.contrib import admin from hello import models # Register your models here. admin.site.register(models.User) admin.site.register(models.Person)

接着刷新下页面,就能看的刚才注册的2个表信息了

显示优化

打开一张表查看详细信息,显示的是User object这种内容,如果想显示具体的标名称,可以用__str__方法,相关语法参考https://www.cnblogs.com/yoyoketang/p/10342017.html

于是可以优化models.py里面的代码,加上一个def __str__(self):

class Person(models.Model):
    '''用户信息''' name = models.CharField(max_length=30) age = models.IntegerField() def __str__(self): return self.__doc__ + ":name>" + self.name class User(models.Model): '''注册表''' user_name = models.CharField(max_length=30, primary_key=True) psw = models.CharField(max_length=30) mail = models.CharField(max_length=30) def __str__(self): return self.__doc__ + ":user_name->" + self.user_name 

刷新amdin后台页面后显示

选个记录点进去就可以对相应的数据增删改查了

 

猜你喜欢

转载自www.cnblogs.com/jason89/p/10359447.html