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:
if j != 2: #j=2时,是最后一次机会,不用在提示还剩余0次机会了
print('用户 %s 密码错误,请重新输入,还有 %d 次机会' % (name,2 - j))
j += 1 #密码输入错误后,循环值增加1
else:
lock_file.write(name + '\n') #密码输入三次错误后,将该用户追加到LOCK文件
sys.exit('用户 %s 达到最大登录次数,将被锁定并退出' % name)
else:
pass #当用户没匹配时,跳过并继续循环
else:
if i != 2: #i=2时,是最后一次机会,不用在提示还剩余0次机会了
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()
python之编写登陆接口(第一天)的更多相关文章
- python 作业 编写登陆接口
# -*- coding:utf-8 -*-import os,sysfor i in range(3):#进行3次循环 blacklist = open(r"C:\Users\Pc4\De ...
- Python之编写登陆接口
1.输入用户名密码: 2.认证成功后显示欢迎信息: 3.错误三次后,账号被锁定. 账号文件:user.txt 锁定文件:locked.txt 流程图如下: # -*- coding:utf-8 -*- ...
- python 之编写登陆接口
基础需求: 让用户输入用户名密码 认证成功后显示欢迎信息 输错三次后退出程序 升级需求: 可以支持多个用户登录 (提示,通过列表存多个账户信息) 用户3次认证失败后,退出程序,再次启动程序尝试登录时, ...
- Python学习第一天-编写登陆接口
编写登陆接口 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定 帐号文件user.txt内容如下: qaz 123qwe 12345qweqwr 12321424...... 锁文件user_l ...
- 使用 Python 编写登陆接口
# 使用 Python 编写登陆接口# Create Date: 2017.10.31 Tuesday# Author: Eric Zhao# -*- coding:utf-8 -*-'''编写登陆接 ...
- Python学习之编写登陆接口(Day1,作业一)
作业一:编写登陆接口 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定(下次登陆还是锁定) 知识点:while循环,for循环,文件操作,if判断,列表操作 思路: 1.登陆,三次登陆失败,锁定 ...
- Python之编写登录接口
作业:编写登陆接口 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定 帐号文件account.txt内容如下: liuyueming 123zhangsan 123lisi 123 锁文件acc ...
- day1作业:编写登陆接口
作业一:编写登陆接口 1.输入用户名和密码 2.认证成功后显示欢迎信息 3.输错三次后锁定 思路:要求是编写登陆接口,那么要有一个存放用户信息的模块:三次后锁定,要有一个存放锁定用户信息的模块:我们知 ...
- day1作业一:编写登陆接口
作业一:编写登陆接口 1.输入用户名和密码 2.认证成功后显示欢迎信息 3.输错三次后锁定 Readme: (1)提示用户输入用户名: (2)用户名验证,验证是否已经锁定: (3)是否锁定:已锁定告诉 ...
随机推荐
- WAF攻防研究之四个层次Bypass WAF
从架构.资源.协议和规则4个层次研究绕过WAF的技术,助于全方位提升WAF防御能力. 绕过WAF的相关技术研究是WAF攻防研究非常重要的一部分,也是最有趣的部分,所以我在写WAF攻防时先写攻击部分.还 ...
- Django URL name详解
我们基于上一节的代码来开始这一节的内容. 上节源代码:zqxt_views(django 1.4 - django 1.10).zip [更新于 2016-09-06 00:13:23] 1. 打开 ...
- 一段可以清理NSArray中的空对象的代码(递归)
- (NSArray *)clearAllNullObject{ NSMutableArray *array = [self mutableCopy]; ;i < array.count;i++ ...
- mysql小结
1.使用密码登录mysql mysql -u root -p 2.查看所有的数据库 show databases; 3.创建数据库 create database <数据库名>; 4.创建 ...
- HTML中head里的内容经浏览器解析后全到body里了
HTML中head里的内容经浏览器解析后全到body里了 修改完代码后,用chrome审查元素,head里的内容都到body中去了 http://bbs.csdn.net/topics/3802586 ...
- 尝试自己翻译了FreeCodeCamp的文章,技术方面多认识了几种技术,文章标题:Transparency in Action Free Code Camp is Now Open Source
这是FreeCodeCamp其中一篇文章,趁着学习英文的时间,翻译这篇文章,其中讲到作者创建FCC过程,本文属于原创,第一次翻译,翻译还有诸多不足之处,请大家包含. 原文地址:https://medi ...
- iOS 面试题(一):寻找最近公共 View --转自唐巧
题目:找出两个 UIView 的最近的公共 View,如果不存在,则输出 nil . 分析:这其实是数据结构里面的找最近公共祖先的问题. 一个 UIViewController 中的所有 view 之 ...
- LeetCode Logger Rate Limiter
原题链接在这里:https://leetcode.com/problems/logger-rate-limiter/ 题目: Design a logger system that receive s ...
- 解决:tomcat部署时deploy location不能显示加载后的路径
项目总是报错,添了删,删了又添了N次以后,发现添加部署的时候,Deploy Location 没有值了,Deploy Location 没有值在自带的Tomcat上就无法用浏览器浏览(Open in ...
- layoutSubviews