python从入门到精通(DAY 3)
作者:hebedich 发布时间:2023-11-03 08:23:18
标签:python入门,python登陆
要求:编写登陆接口
输入用户名密码
认证成功后显示欢迎信息
输错三次后锁定
针对此实例写了有二种类型的脚本,略有不同,具体如下:
帐号文件account.txt内容如下:
sam 123
david 12
kevin 123
lin 12
tailen 123
jack 12
锁文件account_lock.txt默认为空
一、只针对帐号文件里的用户进行判断并锁定,针对用户和密码各有三次错误重试机会。
1、流程图如下:
代码如下:
#!/usr/bin/python27
#_*_ coding:utf-8 _*_
import sys,os,getpass
os.system('clear')
i = 0
while i < 3: #只要用户登录异常不超过3次就不断循环
name = raw_input("请输入用户名:")
lock_file = open('account_lock.txt','r+') #当用户输入用户名后,打开LOCK 文件 以检查是否此用户已经LOCK了
lock_list = lock_file.readlines()
for lock_line in lock_list: #循环LOCK文件
lock_line = lock_line.strip('\n') #去掉换行符
if name == lock_line: #如果LOCK了就直接退出
sys.exit('用户 %s 已经被锁定,退出' % name)
user_file = open('account.txt','r') #打开帐号文件
user_list = user_file.readlines()
for user_line in user_list: #对帐号文件进行遍历
(user,password) = user_line.strip('\n').split() #分别获取帐号和密码信息
if name == user: #如用户名正常匹配
j = 0
while j < 3: #只要用户密码异常不超过3次就不断循环
passwd = getpass.getpass('请输入密码:') #输入隐藏密码
if passwd == password: #密码正确,提示欢迎登录
print('欢迎登录管理平台,用户%s' % name)
sys.exit(0) #正常退出
else:
print('用户 %s 密码错误,请重新输入,还有 %d 次机会' % (name,2 - j))
j += 1 #密码输入错误后,循环值增加1
else:
lock_file.write(name + '\n') #密码输入三次错误后,将该用户追加到LOCK文件
sys.exit('用户 %s 达到最大登录次数,将被锁定并退出' % name)
else:
pass #当用户没匹配时,跳过并继续循环
else:
print('用户 %s 不存在,请重新输入,还有 %d 次机会' % (name,2 - i))
i += 1 #当用户输入错误时,循环值增加1
else:
sys.exit('用户 %s 不存在,退出' % name) #用户输入三次错误后,异常退出
lock_file.close() #关闭LOCK文件
user_file.close() #关闭帐号文件
二、针对帐号文件里的不存在的用户也可以进行判断并锁定,针对用户和密码共有三次错误重试机会
代码如下:
#_*_ coding:utf-8 _*_
import sys,os,getpass
os.system('clear')
retry_limit = 3
retry_count = 0
account_file = 'account.txt'
lock_file = 'account_lock.txt'
while retry_count < retry_limit: #只要重试不超过3次就不断循环
username = raw_input('\033[31;43mUsername:\033[0m')
username = username.strip()
lock_check = open(lock_file) #当用户输入用户名后,打开LOCK 文件 以检查是否此用户已经LOCK了
for line in lock_check.readlines(): #循环LOCK文件
if username == line.strip('\n'): #去掉换行符
sys.exit('\033[35mUser %s is locked!!!\033[0m' % username) #如果LOCK了就直接退出
password = raw_input('\033[32;41mPassword:\033[0m') #输入密码
f = open(account_file,'r') #打开帐号文件
match_flag = False # 默认为Flase,如果用户match 上了,就设置为 True
for line in f.readlines():
user,passwd = line.strip('\n').split() #去掉每行多余的\n并把这一行按空格分成两列,分别赋值为user,passwd两个变量
if username == user and password == passwd: #判断用户名和密码是否都相等
print('hello, %s !!' % username)
match_flag = True #相等就把循环外的match_flag变量改为了True
break #然后就不用继续循环了,直接 跳出,因为已经match上了
f.close()
if match_flag == False: #如果match_flag还为False,代表上面的循环中跟本就没有match上用户名和密码,所以需要继续循环
print('sorry,%s is unmatched' % username)
retry_count += 1 #计数器加1
else:
print('wlecome login my learning system!')
break #用户成功登录,退出脚本
else:
print("you account %s is locked!!!" % username)
g = open(lock_file,'a')
g.write(username) #被锁用户追加到用户锁文件
g.write('\n')
g.close()
0
投稿
猜你喜欢
- php获取图片的exif信息,php自带一个exif_read_data函数可以用来读取图片的exif信息,代码来自php手册<?ph
- Installing mysql (2.8.1) with native extensions /usr/local/lib/ruby/si
- 1、Introduction之前写过2篇文章,分别是:Mysql主从同步的原理 Myql主从同步实战 基于此,我们再实
- 本文实例讲述了Yii2基于Ajax自动获取表单数据的方法。分享给大家供大家参考,具体如下:这里有两张表,表结构如下,locations表存放
- 本文实例讲述了关于php中SimpleXML 函数的用法,此函数是允许您把 XML 转换为对象,分享给大家供大家参考。具体分析如下:Simp
- 如何在页面错误时向数据库中添加记录?在ASP中,我在页面中添加了On Error Resume Next错误命令,以消除和避免程序错误。现在
- PHP simplexml_import_dom() 函数实例获取 DOM 文档节点并转换为 SimpleXML 节点:<?php $
- asp编程中我们经常要处理字符串,比如一个新闻列表,在我们编写asp程序的时候就要考虑到新闻标题的长度不确定性,因为有的文章标题可能很长,可
- 在一行内声明CSS,对比下面两个:h2 {font-size:18px; border:1px solid&n
- 使用cookie来判断来访者身份,是否是首次登陆, asp代码实例如下:< %@ LANGUAGE=&q
- 代码如下:CREATE TABLE [dbo].[TbGuidTable]( [TableName] [varchar](50) NOT N
- 1.方法方法描述bbox(item, column=None)返回指定item的框选范围,或者单元格的框选范围column( cid, op
- 这方面我还是一个freshman,不过看了一些文章,经过一些实践后也算是有了一些想法。希望如果有这方面的前辈路过的话,能不吝指教。首先,作为
- PDOStatement::getColumnMetaPDOStatement::getColumnMeta — 返回结果集中一列的元数据(
- 本文实例讲述了python新式类和经典类的区别。分享给大家供大家参考,具体如下:新式类就是 class person(objec
- PDOStatement::bindValuePDOStatement::bindValue — 把一个值绑定到一个参数(PHP 5 >
- 推荐阅读:使用python检测主机存活端口及检查存活主机下面给大家分享使用python语言实现获取主机名根据端口杀死进程代码。ip=os.p
- 一个申请单可以包含N个项目,添加申请单时就需要动态加入代码了。 动态Table表格 <table border="0&quo
- 在域环境下我没配置成果,也许是域用户的原因,因为我在生产环境下搞的,更改域用户需要重启SQLServer ,所以这个方法放弃了,只能用证书形
- 本文实例讲述了PHP基于phpqrcode生成带LOGO图像的二维码。分享给大家供大家参考。具体如下:这里PHP使用phpqrcode生成带