Djang学习笔记#3 表单

Django中创建一个表单

1.创建表单类在这里插入图片描述
2.添加到视图
在这里插入图片描述
3.渲染到模板在这里插入图片描述
4.在视图中处理表单数据在这里插入图片描述

Form对象的属性和方法

is_bound——是否已经绑定数据
is_valid()——表单是否已经通过验证
cleaned_data——访问表单验证后的数据
as_p()/as_ul()/as_table()——渲染表单
errors——表单验证后的错误信息
fields——表单中的字段
initial——初始化数据

表单字段

表单字段继承自django.forms.Field
每个字段都具有核心参数
每个字段都可以有自定义的验证逻辑
每个字段都有钩子函数,方便扩充功能

字段常用的核心参数

required——是否为必填,默认为True
label——label标签(输入框前的文字描述)
initial——初始化数据
widget——定制界面显示方式(文本框、选择框)
help_text——帮助文字
error_messages——覆盖字段引发异常后的错误显示
localize——本地化,根据用户所在地区格式进行显示
disabled——禁用表单,界面上不可操作
has_changed()——值是否发生了改变

Django的内置字段

文本/字符串
CharField——字符串输入
EmailField——邮件地址输入
URLField——URL地址输入
UUIDField——uuid字符串输入

数值(整数、小数)
FloatField——浮点数输入
IntegerField——整数输入
DecimalField——小数输入(更精确)

选择
ChoiceField——单选
MultipleChoiceField——多选
TypedChoiceField——高级选择(支持结果转换类型)

日期/时间
DateField——日期选择
DateTimeField——日期时间选择
DurationField——时间片段timedelta

文件/文件上传
FileField——文件
FilePathField——文件路径
ImageField——图片

布尔
BooleanField——True/False
NullBooleanField——None/True/False

正则
RegexField——正则输入

单个字段验证

举例:验证用户名为手机号码
第一步:定义clean_xx验证方法
第二步:获取对应的字段值并验证
第三步:验证失败触发forms.ValidationError异常
第四步:返回验证后的数据
第五步:在html页面中显示错误

多个字段综合验证

举例:验证用户名和密码是否正确
第一步:重写clean()方法
第二步:获取用户名和密码数据并验证
第三步:验证失败触发forms.ValidationError异常
第四步:返回验证后的表单数据cleaned_data
第五步:在html页面显示错误non_field_errors

模型表单

修改:
Meta配置选项
widgets——修改展现样式(文本输入、数字输入)
help_texts——设置帮助文字
labels——设置表单输入前的文字提示
error_messages——设置表单的错误提示

文件上传

1.表单设置enctype = “multipart/form-data”
2.在视图中通过request.FILES来获取文件对象
3.将文件保存到磁盘

原始的文件上传:

def file_upload_origin(request):
    """ 原始的文件上传 """
    if request.method == 'POST':
        # 获取上传的文件对象 二进制
        file = request.FILES.get('avatar', None)
        filename = os.path.join(settings.MEDIA_ROOT, 'man.jpg')
        with open(filename, 'wb+') as f:
            for chunk in file.chunks():
                f.write(chunk)
        print('上传成功!')
    return render(request, 'file_upload_origin.html', {

    })

使用form表单实现文件上传:

先定义好form

class AvatarUploadForm(forms.Form):
    """ 头像上传FORM """
    remark = forms.CharField(label='备注', max_length=32)
    avatar = forms.ImageField(label='头像')

实现html、url、views

def file_upload_form(request):
    """ 使用formbiao表单实现文件上传 """
    if request.method == 'POST':
        form = AvatarUploadForm(request.POST, request.FILES)
        if form.is_valid():
            # 保存备注
            # 保存图片
            file = request.FILES.get('avatar', None)
            filename = os.path.join(settings.MEDIA_ROOT, 'man_2.jpg')
            with open(filename, 'wb+') as f:
                for chunk in file.chunks():
                    f.write(chunk)
    else:
        form = AvatarUploadForm()

    return render(request, 'file_upload_form.html', {
        'form': form
    })

实现随机验证码字符串生成算法

import random
import os
from io import BytesIO

from PIL import Image, ImageDraw, ImageFont
from django.conf import settings
from django.http import HttpResponse


class VerifyCode(object):
    """ 验证码类 """

    def __init__(self, dj_request):
        self.dj_request = dj_request
        # 验证码长度
        self.code_len = 4
        # 验证码图片尺寸
        self.img_width = 100
        self.img_height = 30

        # django中session的名称
        self.session_key = 'verify_code'

    def gen_code(self):
        """ 生成验证码 """
        # 1.使用随机数生成验证码字符串
        code = self._get_vcode()
        # 2.把验证码存进session
        self.dj_request.session[self.session_key] = code
        # 3.准备随机元素(背景颜色、验证码文字颜色、干扰线)
        # 字体颜色
        font_color = ['black', 'darkblue', 'darkred',
                      'brown', 'green', 'darkmagenta',
                      'indigo', 'darkcyan', 'teal']
        # RGB随机背景色
        bg_color = (random.randrange(230, 255), random.randrange(230, 255),
                    random.randrange(230, 255))
        # 字体的路径
        font_path = os.path.join(settings.BASE_DIR, 'static', 'fonts', 'timesbi.ttf')

        # 创建图片
        im = Image.new('RGB', (self.img_width, self.img_height), bg_color)
        draw = ImageDraw.Draw(im)

        # 画干扰线
        # 随机条数:画几条干扰线
        for i in range(random.randrange(1, int(self.code_len / 2) + 1)):
            # 线条的颜色
            line_color = random.choice(font_color)
            # 线条的位置
            point = (
                random.randrange(0, self.img_width * 0.2),
                random.randrange(0, self.img_height),
                random.randrange(self.img_width * 0.8, self.img_width),
                random.randrange(0, self.img_height)
            )
            # 线条的宽度
            width = random.randrange(1, 4)
            # 画笔绘画
            draw.line(point, fill=line_color, width=width)

        # 画验证码
        for index, char in enumerate(code):
            # 随机字体颜色
            code_color = random.choice(font_color)
            # 指定字体大小
            font_size = random.randrange(15, 25)
            font = ImageFont.truetype(font_path, font_size)
            point = (index * self.img_width / self.code_len,
                     random.randrange(0, self.img_height / 3))
            draw.text(point, char, font=font, fill=code_color)

        buf = BytesIO()
        im.save(buf, 'gif')
        return HttpResponse(buf.getvalue(), 'image/gif')

    def _get_vcode(self):
        random_str = 'ABCDEFGHIJKLMNPQRSTUVWXYZabcdefghijkmnpqrstuvwxyz23456789'
        code_list = random.sample(list(random_str), self.code_len)
        code = ''.join(code_list)
        return code

    def validate_code(self, code):
        """ 验证验证码是否正确 """
        # 转变大小写
        code = str(code).lower()
        vcode = self.dj_request.session.get(self.session_key, '')

        return vcode.lower() == code

用户认证授权系统

用户:记录用户的登录账号密码等信息
权限:用户是否有权限访问某一资源(执行操作)
组:对多个用户进行权限管理
登录密码:加密后的密码存储
自带后台管理

安装及配置

第一步:INSTALLED_APPS安装应用
‘django.contrib.auth’
‘django.contrib.contenttypes’

第二步:MIDDLEWARE中间配置
SessionMiddleware
AuthenticationMiddleware

第三步:migrate同步模型到数据库

用户模型
分类:
1.User 用户
2.AnonymousUser 游客

常用属性
在这里插入图片描述
在这里插入图片描述
用户登录

步骤一:验证用户
username = authenticate(username=‘jason’, password=‘secret’)
步骤二:判断认证后的用户是否为None
(用户不为None则表示用户认证通过)
步骤三:调用login函数登录用户
login(request, user, backend=None)

用户管理

对用户进行拓展:
两种方式解决
一、使用OneToOneField对用户进行拓展

二、替换现有的用户模型
①配置用户模型,告诉django框架

AUTH_USER_MODEL = 'oauth.User'

②继承自AbstractUser抽象模型
③添加字段,同步模型到数据库
④配置admin

from django.contrib import admin
from django.contrib.auth.admin import UserAdmin
from accounts.models import User

admin.site.register(User, UserAdmin)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值