python:编写登陆接口(day 1)
作业要求:
- 输入用户名,密码
- 认证成功显示欢迎信息
- 输入错误三次后锁定用户
Readme
1.user_id.txt是存放用户id及密码的文件
2.user_lock.txt是存放被锁定的用户id的文档,默认为空.
3.程序会对user_id.txt里的合法用户id进行判断,若连续输入用户id错误达三次程序直接退出.
4.程序会输入对正确用户名后的密码进行判断,输入密码有3次机会,连续三次错误则会锁定用户id并且退出.
流程图:
代码:
#!/user/binenv python3
# -*- coding:utf-8 -*- '''
Created on: 2015年1月16日 @author: 吕毅 Email: 371725153@qq.com Version: 1.0 Description: 输入用户名密码,认证成功显示欢迎信息,认证失败,输错三次后锁定 ''' import sys,os,getpass os.system('clear') #把终端代码页面清空,提供个干净的视觉
i = 0
while i < 3: #只要用户登录异常不超过3次就不断循环
username = input("请输入用户名:") lock_file = open('user_lock.txt','r+') #当用户输入用户名后,打开LOCK 文件 以检查是否此用户已经LOCK了
lock_list = lock_file.readlines() for lock_line in lock_list: #循环LOCK文件
lock_line = lock_line.strip('\n') #去掉换行符
if username == lock_line: #如果LOCK了就直接退出
sys.exit('=======WARNING:该账号 %s 已经被冻结========' % username) user_file = open('user_id.txt','r') #打开帐号文件
user_list = user_file.readlines()
for user_line in user_list: #对帐号文件进行遍历
(user,password) = user_line.strip('\n').split() #分别获取帐号和密码信息
if username == user: #如用户名正常匹配
m = 0
while m < 3: #只要用户密码异常不超过3次就不断循环
passwd = getpass.getpass('请输入密码:') #输入密码,相对安全
if passwd == password: #密码正确,提示欢迎登录
print('HI,%s,欢迎登录系统' % username)
sys.exit(0) #正常退出
else:
if m != 2: #m=2时,是最后一次机会,不用在提示还剩余0次机会了
print('用户 %s 密码错误,请重新输入,还有 %d 次机会' % (username,2 - m))
m += 1 #密码输入错误后,循环值增加1
else:
lock_file.write(username + '\n') #密码输入三次错误后,将该用户追加到LOCK文件
sys.exit('用户 %s 达到最大登录次数,请联系管理员!!' % username)
else:
pass #当用户没匹配时,跳过并继续循环
else:
if i != 2: #i=2时,是最后一次机会,不用在提示还剩余0次机会了
print('用户 %s 不存在,请重新输入,还有 %d 次机会' % (username,2 - i))
i += 1 #当用户输入错误时,循环值增加1
else:
sys.exit('用户 %s 不存在,退出' % username) #用户输入三次错误后,异常退出 lock_file.close() #关闭lock文件
user_file.close() #关闭user_id文件
python:编写登陆接口(day 1)的更多相关文章
- 使用 Python 编写登陆接口
# 使用 Python 编写登陆接口# Create Date: 2017.10.31 Tuesday# Author: Eric Zhao# -*- coding:utf-8 -*-'''编写登陆接 ...
- python 编写登陆接口
#!/usr/bin/env python#_*_ coding:utf-8 _*_dic={ 'yts':{'password':'123','count':0}, 'nick':{'passwor ...
- Python编写登陆接口
实现功能: 输入用户名和密码 认证成功后显示欢迎信息 输错三次后锁定 # 提示输入用户名和密码 # 验证用户名和密码 # 如果错误,则输出用户名或密码错误 # 如果成功,则输出 欢迎,XXX! #!/ ...
- python之编写登陆接口(第一天)
作业:编写登陆接口 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定 针对此实例写了有二种类型的脚本,略有不同,具体如下: 帐号文件account.txt内容如下: sam 123 david ...
- Python学习之编写登陆接口(Day1,作业一)
作业一:编写登陆接口 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定(下次登陆还是锁定) 知识点:while循环,for循环,文件操作,if判断,列表操作 思路: 1.登陆,三次登陆失败,锁定 ...
- Python学习第一天-编写登陆接口
编写登陆接口 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定 帐号文件user.txt内容如下: qaz 123qwe 12345qweqwr 12321424...... 锁文件user_l ...
- day1作业:编写登陆接口
作业一:编写登陆接口 1.输入用户名和密码 2.认证成功后显示欢迎信息 3.输错三次后锁定 思路:要求是编写登陆接口,那么要有一个存放用户信息的模块:三次后锁定,要有一个存放锁定用户信息的模块:我们知 ...
- day1作业一:编写登陆接口
作业一:编写登陆接口 1.输入用户名和密码 2.认证成功后显示欢迎信息 3.输错三次后锁定 Readme: (1)提示用户输入用户名: (2)用户名验证,验证是否已经锁定: (3)是否锁定:已锁定告诉 ...
- (转)python编写登录接口
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://506554897.blog.51cto.com/2823970/1907262 ...
随机推荐
- Calendar抽象类返回自己和Integer.TYPE和int.class
public class Calend { public static void main(String[] args) { Calendar cal=Calendar.getInstance();/ ...
- 2017.11.15 linux软件安装管理(todo)
学习来自:http://www.imooc.com/learn/447 第一章 介绍 第二章 软件包简介 1.源码包 2.二进制包(RPM包或系统默认包) 脚本安装包其实是别人把软件安装的脚本写好了, ...
- onbeforepaste事件用法
onkeyup="value=value.replace(/[^\d]/g,'')" onbeforepaste="clipboardData.setData('text ...
- Dubbo超时重试机制带来的数据重复问题
Dubbo的超时重试机制为服务容错.服务稳定提供了比较好的框架支持,但是在一些比较特殊的网络环境下(网络传输慢,并发多)可能 由于服务响应慢,Dubbo自身的超时重试机制(服务端的处理时间超过了设定的 ...
- 利用Bootstrap制作一个流行的网页
首先是html承载内容: <!DOCTYPE html> <html lang="zh_CN"> <head> <meta charset ...
- leetcode 二分查找 Search in Rotated Sorted Array
Search in Rotated Sorted Array Total Accepted: 28132 Total Submissions: 98526My Submissions Suppose ...
- 深入理解C/C++ [Deep C (and C++)] (2)
好.接着深入理解C/C++之旅.我在翻译第一篇的时候.自己是学到不不少东西,因此打算将这整个ppt翻译完成. 请看以下的代码片段: #include <stdio.h> void foo( ...
- JAVA 模块
commons-lang3 maven repository, 项目主页 fastjson maven repository, 项目主页 fastjson 是阿里巴巴开源的序列化和反序列化 JSON ...
- 【Python3 爬虫】01_简单页面抓取
运行平台:Winodows 10 Python版本:Python 3.4.2 IDE:Sublime text3 网络爬虫 网络爬虫,也叫网络蜘蛛(Web Spider),如果把互联网比喻成一个蜘蛛网 ...
- 【DB2】报错:-30090 25000 指定的操作对远程执行失败
场景描述: 数据库:DB_1,DB_2 现在在DB_1中建立NICKNAME为CST_INFO_NICK,并且该别名指向数据库DB_2的CST_INFO表,在DB_1中建立存储过程,该存储过程需要 ...