码迷,mamicode.com
首页 > 其他好文 > 详细

定义有参装饰器为被装饰函数添加认证功能,定义有参装饰器为被装饰函数添加认证功能,三次验证失败锁定用户

时间:2017-04-12 20:40:31      阅读:199      评论:0      收藏:0      [点我收藏+]

标签:rgs   nbsp   odi   写入文件   and   com   font   not   用户   

#需求:定义有参装饰器为被装饰函数添加认证功能,用户信息的来源可以是文件也可以是ldap         
# 三次验证失败锁定用户
技术分享
 1 def menu():
 2     #用户交互界面
 3     user_name = input("请输入在用户名:")
 4     password = input("请输入密码:")
 5     return user_name,password    #以元组形式返回值
 6 ‘‘‘
 7     alex1  1111
 8     alex2  2222
 9     egon3  3333
10 ‘‘‘
11 def write():
12     #将用户名、密码和登录次数在文件中写成字典的格式
13     user_name_password= {}#设置一个空字典装用户名、密码和登录次数
14     with open("test", encoding="utf8") as date, open("test2", encoding="utf8", mode="w") as revise:
15         for line in date:
16             line1 = line.strip().split()  #以空格分隔后是列表形式
17             user_name_password.setdefault(line1[0],[line1[1],0])#key值为用户名,value值为[密码,登录次数]
18         user_name_password = str(user_name_password)    #将字典转换成字符串
19         revise.write(user_name_password)   #将字典转换成的字符串写入文件test2
20 
21 def main():
22     write() #将用户信息、密码还有登录次数按字典格式写入另一个文件
23     while True:
24         res = menu()#用户名和密码输入,返回值为元组形式(用户名,密码)
25         with open("test2",encoding="utf8") as date:
26             user_name_password = {}  #创建一个空字典,接收用户、密码和登录次数的的数据
27             for line in date:
28                 user_name_password = eval(line) #将用户、密码和登录次数数据转化为字典
29                 if res[0] in user_name_password and user_name_password[res[0]][1] == 3:
30                     #文件中登录名已记录三次,禁止登录
31                     print("登录次数过多锁定")
32                     exit()
33                 if res[0] in user_name_password and res[1] in user_name_password[res[0]][0] and user_name_password[res[0]][1] < 3:
34                     #用户、密码匹配成功和登录次数小于三次,登录成功
35                     print("successful")
36                     current_login["name"] = res[0]
37                     current_login["login"] = True
38                     exit()
39                 if res[0] in user_name_password and res[1] not in user_name_password[res[0]][0]:
40                     #用户匹配,密码不匹配,拉入黑名单,登录次数+1
41                     user_name_password[res[0]][1]=user_name_password[res[0]][1]+1    #登录次数+1
42                     user_name_password.setdefault(res[0],user_name_password[res[0]][1])  #将字典中登录次数的信息进行修改
43                     user_name_password = str(user_name_password)   #将字典转换成字符串
44                     with open("test3", encoding="utf8", mode="w") as revise:
45                         revise.write(user_name_password)  #匹配不成功,将信息写入文件
46                     date.close()   #改文件名需关闭文件
47                     revise.close() #关闭文件需关闭文件
48                     import os
49                     os.rename("test2", "test_bak")
50                     os.rename("test3", "test2")
51                     os.remove("test_bak")  #删除废文件
52                     print("用户名或者密码错误,请重新输入")
53                 else:
54                     print("用户名或者密码错误,请重新输入")
55                     
56 current_login={"name":None,"login":False}  #定义一个字典装已经登录用户的信息
57 def auth2(auth_type):
58     def auth(func):
59         def wrapper(*args,**kwargs):
60             if current_login["name"] and current_login["password"]:
61                 res = func(*args,**kwargs)
62                 return res
63             if auth_type == "file":
64                 main()
65                 res = func(*args,**kwargs)
66                 return res
67             if auth_type == "ldap":
68                 print("还他妈不会玩")
69         return wrapper
70     return auth
71 
72 
73 @auth2(auth_type="file")
74 def index():
75     print("welcome beijing! ")
76 
77 index()
详细代码

 



 

定义有参装饰器为被装饰函数添加认证功能,定义有参装饰器为被装饰函数添加认证功能,三次验证失败锁定用户

标签:rgs   nbsp   odi   写入文件   and   com   font   not   用户   

原文地址:http://www.cnblogs.com/domestique/p/6701072.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!