flask项目简单总结

  •  forms.py表单中需要验证表单:

      1.  validate()  

      2.验证用户是否存在

      3.验证相应的信息是否存在

class RegisterForm(FlaskForm):
    email = EmailField('邮箱', [DataRequired()])
    username = StringField('用户名', [DataRequired(), Length(max=255)])
    password = PasswordField('密码', [DataRequired(), Length(min=6)])
    # company_name = StringField('公司简称', [DataRequired(), Length(max=255)])
    # company_full_name = StringField('公司名称', [DataRequired(), Length(max=255)])
    company_id = StringField('所属公司id', [DataRequired(), Length(max=16)])
    department_id = StringField('所属部门id', [DataRequired(), Length(max=16)])
    phone = StringField('Phone', [DataRequired(), Length(11)])

    def validate(self):
        check_validate = super().validate()
        if not check_validate:
            return False
        check_email = db.session.query(User).filter_by(email=self.email.data).first()
        if check_email:
            self.email.errors.append('邮箱已经存在')
            return False

        return True
  • model.py模型中密码设置
from sqlalchemy.ext.hybrid import hybrid_property
class User(TableBase, db.Model):
    __tablename__ = 'user_user'
    username = db.Column(db.String(255))
    password = db.Column(db.String(255))
    email = db.Column(db.String(255), unique=True)

    @hybrid_property      #私有财产,不能私自访问
    def password_hash(self):
        return self.password

    @password_hash.setter   #可以写密码,可写不可读
    def set_password(self, plaintext):
        self.password = bcrypt.generate_password_hash(plaintext)    #将hash值存入数据库中

    def check_password(self, password):
        return bcrypt.check_password_hash(self.password, password) #判断输入的密码是否在数据库中存在,返回True和False

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值