作业一:编写登陆接口

1.输入用户名和密码

2.认证成功后显示欢迎信息

3.输错三次后锁定

思路:

(1)用户输入用户名;

  (2)去锁定文件中验证用户名是否锁定;

  (3)去当前用户验证用户是否存在;

  (4)用户输入密码,三次输错后锁定

(5)锁定之后从当前文件中删除用户名,添加到锁定文件中。

注意文件的读取、修改、写入操作,这些操作是要借助列表来完成的,不然就会导致一些不必要的错误,最后定义一个函数来完成这些操作,使用的时候调用这些函数就可以了。

列表文件的操作一定要注意换行的处理,如何添加元素进去,这些方法最好借助于列表和字典来读取写入文件,这样能够保持格式的整齐。

代码如下:

import os,sys,getpass,collections
retry_limit = #密码错误三次被锁定
retry_count = #起始次数是0次 def locked_user(users,filename):
#用于存放锁定用户的文件,当用户锁定的时候,要从原文件删除,添加到新的文件中
with open(filename,"w+") as locked_f:
for key,value in users.items():
line = []
line.append(key)
line.append(value)
file_line = " ".join(line) + "\n"
locked_f.write(file_line) active = True
if __name__ == "__main__":
while True:
username = input("请输入用户名(输入quit退出):")
with open("account_lock.txt","r") as f:
user_lists = f.readlines()
for user_list in user_lists:
if user_list.strip() == username:
print("您好,你的用户已经被锁定,请联系管理员!")
continue #如果用户锁定,结束当前循环,执行下一次用户输入
else:
pass
if username == "quit":
sys.exit() with open("account.txt") as active_f:
users_dict = collections.OrderedDict()
for line in active_f:
user,pwd = line.strip().split()
users_dict[user] = pwd if username in users_dict.keys():
while retry_count < retry_limit:
passwd = getpass.getpass("请输入你的密码:") # 隐藏式输入密码
# 判断用户是否在用户列表中
if users_dict[username] == passwd:
print("欢迎回来,认证成功!")
break
else:
if retry_count != :
#提示用户注意,还有几次机会将被锁定
print("您输入的密码不对,您还有%d次机会,否则系统将被锁定!" % ( - retry_count))
retry_count += else:
print("您输入的次数过多,%s已被锁定,请联系管理员" %username) #用户锁定之后,要把锁定的用户从当前文件删除,移到锁定文件中
users_dict.pop(username)
locked_user(users_dict,"account.txt")
with open("account_lock.txt","a+") as a_f:
a_f.write(username + "\n")
else:
print("对不起,您输入的用户不存在,请重新输入!!!")

上面代码实现了登录接口的功能,但是有一些小小的瑕疵,就是锁定文件的写入不是很好,会出现两个空行的情形,这种方式就只能写读取之前的文件,放到一个列表中,然后把锁定用户添加到这个列表,重新再次读入文件,下面将对代码进行修正。

 import os,sys,getpass,collections

 def locked_user(users,filename):
#用于存放锁定用户的文件,当用户锁定的时候,要从原文件删除,添加到新的文件中
with open(filename,"w+") as locked_f:
for key,value in users.items():
line = []
line.append(key)
line.append(value)
file_line = " ".join(line) + "\n"
locked_f.write(file_line) active = True
if __name__ == "__main__":
while True:
retry_limit = # 密码错误三次被锁定,每次循环重置
retry_count = # 起始次数是0次,每次循环重置次数
username = input("请输入用户名(输入quit退出):")
with open("account_lock.txt","r") as f:
user_lists = f.readlines()
for user_list in user_lists:
if user_list.strip() == username:
print("您好,你的用户已经被锁定,请联系管理员!")
break #如果用户锁定,结束当前循环,执行下一次用户输入
else:
pass
if username == "quit":
sys.exit() with open("account.txt") as active_f:
users_dict = collections.OrderedDict()
for line in active_f:
user,pwd = line.strip().split()
users_dict[user] = pwd if username in users_dict.keys():
while retry_count < retry_limit:
passwd = input("请输入你的密码:") # 隐藏式输入密码
# 判断用户是否在用户列表中
if users_dict[username] == passwd:
print("欢迎回来,认证成功!")
break
else:
if retry_count != :
#提示用户注意,还有几次机会将被锁定
print("您输入的密码不对,您还有%d次机会,否则系统将被锁定!" % ( - retry_count))
retry_count += else:
print("您输入的次数过多,%s已被锁定,请联系管理员" %username) #用户锁定之后,要把锁定的用户从当前文件删除,移到锁定文件中
users_dict.pop(username)
locked_user(users_dict,"account.txt")
with open("account_lock.txt","r") as a_f:
#先读取文件放入一个列表中,以方便下一次读取
user_lines = a_f.readlines() #按行读取文件
user_messages = []
for user_line in user_lines:
user_messages.append(user_line.strip())
user_messages.append(username) #锁定用户添加到列表中
print(user_messages)
with open("account_lock.txt","w+") as write_f:
#把包含锁定用户的列表重新写会文件中
for user_message in user_messages:
user_message = user_message + "\n"
write_f.write(user_message) else:
print("对不起,您输入的用户不存在,请重新输入!!!")
运行如下:
请输入用户名(输入quit退出):zeng
请输入你的密码:222
您输入的密码不对,您还有2次机会,否则系统将被锁定!
请输入你的密码:222
您输入的密码不对,您还有1次机会,否则系统将被锁定!
请输入你的密码:222
您输入的次数过多,zeng已被锁定,请联系管理员
['chang', 'geng', 'xue', 'zeng']
请输入用户名(输入quit退出):zhu
请输入你的密码:333
您输入的密码不对,您还有2次机会,否则系统将被锁定!
请输入你的密码:333
您输入的密码不对,您还有1次机会,否则系统将被锁定!
请输入你的密码:333
您输入的次数过多,zhu已被锁定,请联系管理员
['chang', 'geng', 'xue', 'zeng', 'zhu']
请输入用户名(输入quit退出):quit

代码中,我们在写入文件的时候经过了一步转换,如下图所示:

上面是文件转换的过程,这种方法是常用的文件处理的形式,但是要注意,使用"w"读取文件的时候,一定要特别注意,这种方式会情况原有的文件内容,一定要谨慎使用,别一不小心把公司文件库情况了,到时候老板pass你。

day1作业:登录接口的更多相关文章

  1. Day1作业---登录接口及多级菜单

    #!/usr/bin/env python # -*- coding:utf-8 -*- # Author:Ma Qing data = { "山东" :{ "济南&qu ...

  2. day1作业--登录接口

    作业:编写登陆接口 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定     知识: 1.循环的使用: 2.continue,break在循环中中断的作用: 3.文件的写入,读取: 4.各基础知 ...

  3. day1作业登录接口总结

    作业一:编写登陆接口 1.输入用户名和密码 2.认证成功后显示欢迎信息 3.输错三次后锁定 上面作业,用了几种思路来解决问题:但是本质上其实都是一样的:核心都是对文件的操作,文件的增删改查:并且这些操 ...

  4. day1作业--登录入口

    作业概述: 编写一个登录入口,实现如下功能: (1)输入用户名和密码 (2)认证成功后显示欢迎信息 (3)输错三次后锁定 流程图: readme: 1.程序配置文件: 黑名单文件blacklist.t ...

  5. Python作业--登录接口

    作业需求: 编写登陆接口 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定 实现思路: 1.从文件获取用户名密码 2.判断是否在黑名单中 3.验证用户名密码 成功:输出认证成功 错误:判断验证次 ...

  6. python基础一之课后作业:编写登录接口

    1 # Author : Mamba 2 3 #python基础一之课后作业:编写登录接口 4 5 # 输入用户名密码 6 # 认证成功后显示欢迎信息 7 # 用户名3次输入错误后,退出程序 8 # ...

  7. day1 作业编写登录窗口

    作业一:编写登录接口 (1)输入用户名和密码: (2)认证成功后显示欢迎信息: (3)输错三次后锁定. 思路:我们知道,要想让程序记住之前输入多少次,锁定用户,那么可以使用数据库来保存用户的状态,然而 ...

  8. Day1作业要求

    Day1作业 作业需求 博客 模拟登录 三级菜单 博客地址 杨振伟Day1博客地址 模拟登录 1.程序说明 实现功能如下 用户输入密码,密码验证后登录成功 用户登录成功后提示登录信息 用户输入3次错误 ...

  9. (转)python编写登录接口

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://506554897.blog.51cto.com/2823970/1907262 ...

随机推荐

  1. openstack虚拟机启动过程源码分析

    源码版本:H版 以nova-api为起点开始分析! 一.在nova-api进程中进行处理 根据对nova api的分析,当请求发过来的时候,由相应的Controller进行处理,此处如下: nova/ ...

  2. MySQL报错】ERROR 1558 (HY000): Column count of mysql.user is wrong. Expected 43, found 39.

    之前在centos6.4系统安装的是自带的mysql 5.1版本,后来升级到了5.6版本,执行以下命令报错 在网上查找原因说说因为升级不当导致,执行以下命令即可正常执行命令 mysql_upgrade ...

  3. openwrt的sysupgrade和factory固件的区别

    openwrt的固件一般分两种类型:factory原厂固件.sysupgrade固件 factory多了一些验证的东西,用于在原厂固件的基础上进行升级. 普通家用路由一般不是openwrt固件,如果要 ...

  4. [vmware]另类解决vmware关闭win10死机或蓝屏问题

    升级win10后在使用虚拟机发生一个问题,本人的win10版本为win10 9879, 在使用vmware时,当关机会整个系统死机,在网上搜索后发现这是由于win10内核升级导致vmware不兼容,最 ...

  5. 20155301 2016-2017-2 《Java程序设计》第5周学习总结

    20155301 2016-2017-2 <Java程序设计>第5周学习总结 教材学习内容总结 1.1try.catch关键词,在用户不小心输入错误的时候,程序会出现错误信息,将代表错误的 ...

  6. 【leetcode 简单】 第八十八题 猜数字大小

    我们正在玩一个猜数字游戏. 游戏规则如下: 我从 1 到 n 选择一个数字. 你需要猜我选择了哪个数字. 每次你猜错了,我会告诉你这个数字是大了还是小了. 你调用一个预先定义好的接口 guess(in ...

  7. Linux基础-sed+正则表达式

    1,删除文件每行的第一个字符:sed -r 's/^.//g' passwd 2,删除文件每行的第二个字符:sed -r 's/^(.)(.)/\2/g' passwd 3,删除文件每行的最后一个字符 ...

  8. Linux下inittab文件详解

    /etc/inittab文件详解 Linux系统的启动过程为:加电自检-->根据BIOS中的设置从指定的设备启动-->找到设备MBR中的bootloader引导启动系统-->启动ke ...

  9. JS设计模式——6.方法的链式调用

    什么是链式调用 这个很容易理解,例如: $(this).setStyle('color', 'red').show(); 分解链式调用 链式调用其实是两个部分: 1.操作对象(也就是被操作的DOM元素 ...

  10. c++ static静态

    在C++中,静态成员是属于整个类的而不是某个对象,静态成员变量只存储一份供所有对象共用.所以在所有对象中都可以共享它.使用静态成员变量实现多个对象之间的数据共享不会破坏隐藏的原则,保证了安全性还可以节 ...