导语:
本文主要介绍了关于python中怎么获取密码输入次数的相关知识,包括python输入三次密码程序,以及python字符出现的次数这些编程知识,希望对大家有参考作用。
Python判断用户密码输入次数的代码如下:
# 判断用户是否锁定
now_time = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')
nowTime = datetime.datetime.strptime(now_time, '%Y-%m-%d %H:%M:%S')
# 距离上次操作时间大于24小时,重置
if (nowTime - user.update_time).total_seconds() > ONE_DAY_TIME:
user.pass_errnum = 0
user.login_sta = False
user.login_suo = datetime.datetime.now()
# 判断账户是否锁定
if user.login_sta == True:
time = user.login_suo + datetime.timedelta(days=1)
# 账户锁定时间
if (nowTime - user.login_suo).total_seconds() < ONE_DAY_TIME:
return jsonify(errno=RET.REQERR, errmsg='该账户已经锁定,请%s后再执行操作!' % time)
else:
user.pass_errnum = 0
user.login_sta = False
user.login_suo = datetime.datetime.now()
# 判断用户名密码输入次数
if user.pass_errnum >= 5:
user.login_suo = datetime.datetime.now()
user.login_sta = True
return jsonify(errno=RET.REQERR, errmsg='密码输入超过5次,请24小时后再执行操作!')
# 判断密码是否正确
if user.password_hash != passwd:
user.pass_errnum += 1
num = 5 - user.pass_errnum
if num == 0:
return jsonify(errno=RET.REQERR, errmsg='你今日的登录次数已用完!')
return jsonify(errno=RET.PWDERR, errmsg='用户名或密码错误,还有%d次机会!' % num)
附:数据库字段
login_sta = db.Column(db.Boolean, default=False) # 登录是否锁定
login_suo = db.Column(db.DateTime, default=datetime.now) # 登录锁定时间
pass_errnum = db.Column(db.Integer, default=0) # 用户密码输入次数
推荐学习《
》。
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ python Helium库是如何实现web自动化的?11/14
- ♥ python sys模块有什么用12/20
- ♥ python eval和exec有什么区别11/20
- ♥ openpyxl如何在sheet中读写数据09/18
- ♥ python如何查看错误类型是什么?10/31
- ♥ exec()函数如何在python中执行表达式?01/07
内容反馈