python

超轻量级php框架startmvc

Python模拟用户登录验证

更新时间:2020-05-07 05:24 作者:startmvc
本文实例为大家分享了Python模拟用户登录验证的具体代码,供大家参考,具体内容如下1.功

本文实例为大家分享了Python模拟用户登录验证的具体代码,供大家参考,具体内容如下

1.功能简介

此程序模拟用户登录验证的过程,实现用户名输入、黑名单检测、用户有效性判别、密码输入及验证等。用户在3次以内输入正确密码登陆成功,连续输错3次密码登陆失败,且该用户名被记录在黑名单,黑名单中的用户被锁定不能再登陆。

2.实现方法

本程序采用python语言编写,将各项任务进行分解并用定义对应的函数来处理,从而使程序结构清晰,易于维护。主要编写了四个函数:

login() #登陆函数,为主函数,完成用户名检测和密码验证 inquire_blacklist(name) #查询用户名是否在黑名单中 inquire_userlist(name) #查询用户名是否在用户名单中,并返回密码或None add_blacklist(name) #添加用户名到黑名单文件 函数调用框架:运行login()-->输入用户名-->调用inquire_blacklist(name)进行黑名单检测-->调用inquire_userlist(name)进行用户名有效性判别,有效则返回用户密码,再与输入密码对比验证-->连续输错3次密码则调用add_blacklist(name)添加用户到黑名单。

3.流程图

4.代码


# Author:Byron Li

import os
BASE_DIR = os.path.dirname(__file__) #获取文件目录路径
userlist='userlist.txt' #存取已注册用户名单文件,包括用户名和密码
blacklist='blacklist.txt' #存取锁定用户的黑名单文件
userlist_path = os.path.join(BASE_DIR,userlist) #注册用户名单文件路径
blacklist_path = os.path.join(BASE_DIR,blacklist) #黑名单文件路径

#---------------------------登陆函数(主函数)--------------------------
def login(): #登陆函数
 username = input("请输入用户名:")
 while(True):
 if inquire_blacklist(username): #查询输入用户名是否在黑名单中
 print("不好意思,此用户名\"%s\"已被锁定,禁止登陆!"%username)
 return False
 else:
 user_password = inquire_userlist(username) #查询输入用户名是否存在注册用户名单中,若存在则返回该用户密码
 if user_password:
 for i in range(3):
 password = input("请输入密码:") if i==0 else input("密码输入错误,请重新输入密码:")
 if password==user_password:
 print('欢迎%s登陆!'%username)
 return True
 else:
 print("您已经连续输错密码3次,用户名将被锁定,禁止再登陆!")
 add_blacklist(username) #添加用户名到黑名单文件
 return False
 else:
 username = input('无效的用户名,请重新输入:')
# ------------------------------------------------------------


#-----------------查询黑名单函数-------------------------------
def inquire_blacklist(name): #查询用户名是否在黑名单中
 with open(blacklist_path, 'r') as f:
 for line in f:
 if name==line.strip():
 return True
 return False
# ------------------------------------------------------------- 

#-----------------------查询用户名函数--------------------------
def inquire_userlist(name): #查询用户名是否在注册用户名单中
 with open(userlist_path, 'r') as f:
 for line in f:
 [username,password] = line.split()
 if name==username:
 return password
 return None
# ------------------------------------------------------------


#-----------------------------添加黑名单函数--------------------
def add_blacklist(name): #添加用户名到黑名单文件
 with open(blacklist_path, 'a') as f:
 f.write(str(name)+'\n')
 return True
# ------------------------------------------------------------------------------
if login(): #执行登陆函数
 print('登陆成功!'.center(47,'*'))
else:
 print('登陆失败!'.center(47,'*'))

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。