5. 自定义过滤器和模板标签

5.1 新建templatetags模块

Django项目知识点(二)_python
  • app 目录下,新建templatetags 模块(不是文件夹)

  • 再到 templatetags下创建py文件(名字就是过滤器的名称)

注意:templatetags这个目录名字是固定的,而里面的模块名是自定义的.

5.2 注册过滤器

  1. 通过django.template.Library 它的实例的 filter 方法

filter 有两个参数:

  • name 过滤器的名称,是个字符串,默认使用方法名作为过滤器的名称

  • filter_func 定义的过滤器的函数

例子

现在需要把性别1变为男。0对应女

Django项目知识点(二)_python_02在这里插入图片描述
这就应该写自定义过滤器


Django项目知识点(二)_python_03在这里插入图片描述
通过{% load %} 加载自定义过滤器


Django项目知识点(二)_python_04在这里插入图片描述
在加载过滤器的html中引入函数的名称
Django项目知识点(二)_python_05在这里插入图片描述
效果如下
Django项目知识点(二)_python_06在这里插入图片描述

还可以通过: 来传入参数

Django项目知识点(二)_python_07在这里插入图片描述

效果如下:

Django项目知识点(二)_python_08在这里插入图片描述

5.3 自定义模板标签

  • 自定义简单标签

通过@register.simple_tag()注册,可以设置name属性,不设置就是函数名

这里的context通过view传递的,需要在simple_tag 中,设置参数take_context=True,可以在自定义的模板标签中拿到context中的format_str

Django项目知识点(二)_python_09在这里插入图片描述

将日期的format_str传入

Django项目知识点(二)_python_10在这里插入图片描述

这让就可以将datetime的改成自己想要的类型

Django项目知识点(二)_python_11在这里插入图片描述
  • 自定义包含标签(在特定html传入参数)

通过@register.inclusion_tag()定义

Django项目知识点(二)_python_12在这里插入图片描述Django项目知识点(二)_python_13在这里插入图片描述

student从view中导入到index.html

Django项目知识点(二)_python_14加粗样式

stu.course是模型那边的

Django项目知识点(二)_python_15在这里插入图片描述

效果如下

Django项目知识点(二)_python_16在这里插入图片描述

6. 用户注册

官方文档

django的强大之处在于开发效率高,内置了权限模块之类的很多常用功能。django内置权限系统有大的自定义功能扩展,不需要重复造轮子。

  • 在settings.py中设置AUTH_USER_MODEL指向user的app的User模型

# 自定义用户模型
# 这里的user是app,User是模型 不是固定的
AUTH_USER_MODEL = 'user.User'

6.1 UserManager

  • UserManager这是django用户管理者

通过python manage createsupermanage来创建超级用户,但是有的时候还需要超级用户的其他字段,如email

user app下的model

from  django.contrib.auth.models import AbstractUser,UserManager as _UserManager
# Create your models here.
class UserManager(_UserManager):
    '''
    自定义usermanage 修改时使用python manage createsupermanage命令时,我可以不提供email字段
    '''

    def create_superuser(self,username,password,email= None,**extra_fields):
        return  super().create_superuser(username=username,password=password,email=email,**extra_fields)

这里将内置的UserManager命名为_UserManager,来改写UserManager

这是UserManager的源码

Django项目知识点(二)_python_17

通过上面改写UserManager的create_superuser创建超级用户可以不提供email字段

6.2 AbstractUser

  • AbstractUser这是django特定的抽象用户

导入方式 : from django.contrib.auth.models import AbstractUser

创建用户的model,继承了AbstractUser

class User(AbstractUser):
    """
    add mobile, email_active fields to Django user model.
    """

    mobile = models.CharField('手机号', max_length=11, unique=True, help_text='手机号', error_messages={'unique''此手机号码已注册'})
    email_active = models.BooleanField('邮箱状态', default=False)
    class Meta:
        db_table = 'tb_user'    # 指定数据库表名
        verbose_name = '用户'     # 在admin站点中显示名称
        verbose_name_plural = verbose_name  # 显示复数
    def __str__(self):
        return self.username
    # A list of the field names that will be prompted for
    # when create a user via createsuperuser management command.
    # 必需字段
    REQUIRED_FIELDS = ['mobile']
    # specify manager
    objects = UserManager()

标准的用户注册流程

Django项目知识点(二)_python_18
  • 注册页面

  • 图片验证码

  • 用户名检测是否注册

  • 手机号检测是否注册

  • 短信验证码

  • 注册保存用户数据

因为图片验证码,短信验证码考虑到后续可能会在其他业务中用到,因此将验证码功能独立出来,创建一个新appverification。在项目中一般叫verification 验证的意思

用户校验典型的POST,需创建forms.py

from django_redis import get_redis_connection
class RegisterForm(forms.Form):
    """
    用户注册表单
    """

    username = forms.CharField(label='用户名', max_length=20, min_length=5, error_messages={
        'max_length''用户名长度要小于20',
        'min_length''用户名长度要大于5',
        'required''用户名不能为空',
    })
    password = forms.CharField(label='密码', max_length=20, min_length=6, error_messages={
        'max_length''密码长度要小于20',
        'min_length''密码长度要大于5',
        'required''密码不能为空',
    })
    password_repeat = forms.CharField(label='确认密码', max_length=20, min_length=6, error_messages={
        'max_length''密码长度要小于20',
        'min_length''密码长度要大于5',
        'required''密码不能为空',
    })
    mobile = forms.CharField(label='手机号码', max_length=11, min_length=11, validators=[mobile_validator, ], error_messages={
        'max_length''手机号码长度不正确',
        'min_length''手机号码长度不正确',
        'required''手机号码不能为空',
    })
    sms_code = forms.CharField(label='短信验证码', max_length=constants.SMS_CODE_LENGTH, min_length=constants.SMS_CODE_LENGTH, error_messages={
        'max_length''短信验证码长度不正确',
        'min_length''短信验证码长度不正确',
        'required''短信验证码不能为空',
    })

    def clean_username(self):
        """
        校验用户名
        :return:
        """

        username = self.cleaned_data.get('username')

        if User.objects.filter(username=username).exists():
            raise forms.ValidationError('用户名已存在!')

        return username

    def clean_mobile(self):
        """
        校验手机号码
        :return:
        """

        mobile = self.cleaned_data.get('mobile')

        if User.objects.filter(mobile=mobile).exists():
            raise forms.ValidationError('手机号码已注册!')

        return mobile

    def clean(self):
        """
        联合校验
        :return:
        """

        clean_data = super().clean()
        # 校验密码是否一致
        password = clean_data.get('password')
        password_repeat = clean_data.get('password_repeat')

        if password != password_repeat:
            raise forms.ValidationError('两次密码不一致!')

        # 校验短信验证码
        sms_code = clean_data.get('sms_code')
        moblie = clean_data.get('mobile')

        redis_conn = get_redis_connection(alias='verify_code')
        real_code = redis_conn.get('sms_text_{}'.format(moblie))
        if (not real_code) or (real_code.decode('utf-8') != sms_code):
            raise forms.ValidationError('短信验证码错误!')

上面的代码只做参考

有点长,先在此处断开


Django项目知识点(二)_python_19


一直原创,从未转载

请认准我,将我置标

Django项目知识点(二)_python_20


转发,好看支持一下,感谢