一、认证系统
使用django本身自带的认证系统
1、登录admin后台
1. 先建立一个管理员用户:
> python manage.py creatsuperuser
输入用户名、邮箱和密码即可创建一个管理员用户。
2. 使用超级用户登录系统
管理员用户登录地址:localhost:8000/admin/。登录后可以创建一个用户
3. 引用Django的认证登录
...... from django.contrib import auth ...... def login_action(request): if request.method == 'POST': username = request.POST.get('username', '') password = request.POST.get('password', '') user = auth.authenticate(username=username, password=password) if user is not None: auth.login(request, user) request.session('user') = username response = HttpResponseRedirect('/event_manage/') return response else: return render(request, 'index.html', {'error': 'username or password error!'})
二、进行登录认证
直接在地址中输入localhost:8000/event_manage/ 是可以直接进入到登录成功页面的。因此需要加入一个登录认证。
引入login_request函数
views.py ...... from django.contrib.auth.decorators import login_request ...... # 发布会管理 @login_request def event_manage(request): username = request.session.get('user', '') return render(request, 'event_manage.html', {'user': username})
三、Django模型
1、django模型知识
模型对应系统的一张表,每个模型是一个python类,继承django.db.models.Model类
该模型的每个属性表示一个数据库表的字段
2、打开models.py文件创建模型
models.py from django.db import models class Event(models.Model): name = models.CharField(max_length=200) limit = models.IntergerField() status = models.BooleanField() address = models.CharField(max_length=200) start_time = models.DateTimeField('events time') creat_time = models.DateTimeField(auto_now=True) def __str__(self): return self.name class Guest(models.Model): event = models.Foreignkey(Event) realname = models.CharField(max_length=60) phone = models.CharField(max_length=16) email = models.EmailField() sign = models.BooleanField() create_time = models.DateTimeField(auto_now=True) class Meta: unique_together = ("event", "phone") def __str__(self): return self.realname
3、需要进行数据迁移
>pthon manage.py makemigrations sign >python manage.py migrate
4、通过Admin后台管理数据
from django.contrib import admin from sign.models import Event, Guest admin.site.register(Event) admin.site.register(Guest)
通过上面的代码“注册”后,admin后台将会有Event和Guest的数据项。添加一条记录可以看到默认显示的是name和realname,这是因为我们在类Event和Guest的__str__中返回的是name和realname。
5、显示更多的字段
from django.contrib import admin from sign.models import Event, Guest class EventAdmin(admin.ModelAdmin): list_display = ['id', 'name', 'status', 'address', 'start_time'] # 添加的字段 search_fields = ['name'] # 搜索栏 list_filter = ['status'] # 过滤器 class GuestAdmin(admin.ModelAdmin): list_display = ['realname', 'phone', 'email', 'sign', 'create_time', 'event'] search_fields = ['realname', 'phone'] # 搜索栏 list_filter = ['sign'] admin.site.register(Event, EventAdmin) admin.site.register(Guest, GuestAdmin)
django提供了大量的自定义模块工具,这些选项在ModelAdmin类中,所以需要创建一个类来继承admin.ModelAdmin类。选项如:list_display,search_fields,list_fielder等
最后使用新建的类来分别注册Event和Guest。
6、数据库切换
本身系统默认支持的是sqlite数据库,现在使用mysql数据库也是可以的。
修改对应的配置文件之后,再进行数据迁移即可以进行数据库的切换。
1.创建一个名为guest的数据库
2.修改配置文件setting.py
DATABASES = { 'default': { # 'ENGINE': 'django.db.backends.sqlite3', # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), 'ENGINE': 'django.db.backends.mysql', 'HOST': '127.0.0.1', 'PORT': '3306', 'NAME': 'guest', 'USER': 'root', 'PASSWORD': '123456', 'OPTIONS': { 'init_command': "SET default_storage_engine=INNODB;", }, } }
3.进行数据迁移
> python manage.py migrate
PS:如果遇到出现 1193, "Unknown system variable 'storage_engine'" 的报错,那是因为mysql5.7版本以上需要改配置文件,将OPTION项改为"OPTIONS":{"init_command":"SET default_storage_engine=INNODB;"}