• 【flask+python】利用魔术方法,更优雅的封装model类


    定义model

    # @Time      :2024-2024/2/27-14:49
    # @Email     :514422868@qq.com
    # @Author    :Justin
    # @file      :user.py
    # @Software  :01-fishbook
    from app.model.base import Base
    from sqlalchemy import Column, Integer, SmallInteger, String
    from werkzeug.security import generate_password_hash, check_password_hash
    
    
    class User(Base):
        # auto_increment=True 不需要auto_increment
        id = Column(Integer, primary_key=True)
        nickname = Column(String(32), index=True, nullable=False, unique=True)
        email = Column(String(32), index=True, nullable=False, unique=True)
        status = Column(SmallInteger, default=1)
        _password = Column("password", String(256))
    
        @property
        def password(self):
            return self._password
    
        # 这里必须是属性名称
        @password.setter
        def password(self, raw):
            self._password = generate_password_hash(raw)
    
        def check_password(self, raw: str):
            # 必须是先是加密之后的密码,再是原始密码
            return check_password_hash(self.password, raw)
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31

    里面的注释要好好看,
    注意@property是 obj.password时触发,因为password是密文存储的,
    所以,在赋值时指向password(self,raw)的方法,将它加密
    使用的generate_password_hash 和 check_password_hash 都是werkzeug.security下的方法。

    因为两个魔力函数的存在,使得,
    涉及密码时不可以传统的方式验证用户是否存在

    def find_user():
        with app.app_context():
            # 上面一种查询方式错误,因为对password的属性进行了getter和setter的装饰器修饰
            # User.query.filter_by(email=email, password=password).first()
            # 正确的方式应用这样
            # user = User.query.filter_by(_password="123456").first()
            # 业务上的使用方式是这样:
            param = {
                "email": "a@qq.com",
                "password": "123456"
            }
            user = User.query.filter_by(email=param["email"]).first()
            if user:
                print(user.check_password(param["password"]))
            print(user)
            a_en = generate_password_hash("a")
            print(check_password_hash(a_en, "a"))
            print(a_en)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    filter的妙用

    	@property
        def intro(self):
            self.intro = filter(lambda x: True if x else False, [self.author, self.publisher, self.price])
    
    • 1
    • 2
    • 3
  • 相关阅读:
    【论文阅读】RadHAR:通过毫米波雷达生成的点云识别人类活动
    取Dataset子集(pytorch)
    电脑重装系统桌面图标变成白色文件怎么恢复?
    Webots将节点复制到不同工程中
    【软考中级】网络工程师:7.下一代互联网
    最优闭回路问题
    【深入浅出 Yarn 架构与实现】4-6 RM 行为探究 - 申请与分配 Container
    阿里老哥独家珍藏的Java面试突击宝典,轻松应对95%秋招面试题
    NameNode 和 SecondaryNameNode 工作机制
    学习笔记-SSRF
  • 原文地址:https://blog.csdn.net/weixin_40293999/article/details/136329001