python实现用户管理系统的方法-创新互联
小编给大家分享一下python实现用户管理系统的方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
目前创新互联建站已为1000多家的企业提供了网站建设、域名、虚拟主机、网站托管、企业网站设计、东阿网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。一、题目描述
userpw2.py。下面的问题和例题7.1中的管理名字-密码的键值对数据程序有关。
(a) 修改那个脚本,使他能记录用户上次的登陆日期和时间(用time模块),并与用户密码一起保存起来。程序的界面要求用户输入用户名和密码的提示。无论用户名是否登陆成功,都应有提示,在用户登陆成功后,应更新相应用户的上次登陆时间戳。如果本次登陆与上次登陆在时间上相差不超过四个小时,则通知该用户:“You already in at :
(b) 添加一个管理菜单,其中有以下两项:(1)删除一个用户 (2)显示系统中所有用户的名字和他们密码的清单。
(c) 口令目前没有加密。请添加一段对口令加密的代码
(d) 为程序添加图形界面,例如,用Tkinter。(图形化界面开发比较复杂,这里没有用到。)
(e) 要求用户名布区分大小写。
(f ) 加强对用户名的限制,不允许符号和空白符。
(g) 合并“新用户”和“老用户”两个选项。如果一个新用户试图用一个不存在的用户名登陆,询问该用户是否是新用户,如果是肯定的,就创建该用户。否则按老用户的方式登陆。
二、程序中用到的模块,解释如下:
(1) re:正则表达式引擎,python中调用正则表达式的方法
(2) pickle:对象持久化,将数据写入到磁盘中
(3) datetime:时间处理,用于记录用户登陆时间戳
(4) base64:base64加密模块
(5) hashlib:hash加密模块
完整代码:
#-*- coding:utf-8 -*- #2017.7.17 import re import pickle import base64,hashlib from datetime import datetime def Initialization(file_name): '''''程序初始化,创建user.ini和time.ini文件''' dict_test={'admin':'db69fc039dcbd2962cb4d28f5891aae1'} #创建超级管理员,默认密码为admin f = file(file_name,'a+') #以追加的方式打开文件,避免文件被修改 if len(f.readlines()) ==0: #判断程序是否为空,只在第一次运行的时候初始化 if file_name=='user.ini': pickle.dump(dict_test, f, True) else: pickle.dump({},f, True) f.close() def encodepass(passwd): '''''采用base64和md5双层加密,破解可能几乎为0''' m = hashlib.md5() pwd = base64.b64encode(passwd) m.update(pwd) return m.hexdigest() def time_order(user): '''''记录用户登陆时间,结果保存在time.ini文件中''' ft = file('time.ini','r') dbt = pickle.load(ft) if user not in dbt: dbt.setdefault(user,datetime.today()) else: time_value = dbt[user] t = datetime.today()-time_value try: if t.hour<=4: print 'You already logged in at:' except: print 'You already logged in at: ' dbt[user] = datetime.today() ft = file('time.ini','w') pickle.dump(dbt, ft, True) ft.close() def newuser(db): '''''用户创建程序,由olduser调用''' while True: name = raw_input('Please input the username:') if re.match(r'\w', name): #采用正则表达式检测用户名是否合法 pass else: print 'Username should be made of A~Z、a~z、0~9、_' continue for valuename in db.keys(): if name.lower() == valuename.lower(): break else: break passwd = raw_input('Please input the password:') db[name] = encodepass(passwd) def olduser(db): '''''用户登陆程序''' name = raw_input('Login:') if name in db: pwd = raw_input('passwd:') passwd = db.get(name) if passwd == encodepass(pwd): print 'Welcome back!',name time_order(name) else: print 'Login incorrent!' else: YN = raw_input('Do you want to instead a new user? Yes or No:') if YN.lower()=='yes': newuser(db) print '\n', def deluser(db): '''''删除一个用户,但必须以管理员的身份''' print 'Please login as admin' #管理员的身份才能删除用户 name = raw_input('Login:') pwd = raw_input('passwd:') passwd = db.get(name) if passwd == encodepass(pwd) and name=='admin': user = raw_input('Please input a user name:') if user != 'admin': if db.pop(user): print 'Delete Current!' else: print 'Con not delete admin!' else: print 'Wrong passwprd' def checkuser(db): '''''查看所有用户,但必须以管理员的身份''' print 'Please login as admin' #管理员的身份才能查看所有用户 name = raw_input('Login:') pwd = raw_input('passwd:') passwd = db.get(name) if passwd == encodepass(pwd) and name == 'admin': for key in db: print 'username: %10s ====> password: %10s' % (key,db[key]) else: print 'You can not check all users!' def resetuser(db): '''''修改密码,但必须正确的输入老密码''' name = raw_input('Please input the username:') passwd = raw_input('Please input old password:') if db[name] == encodepass(passwd): passwd = raw_input('Please input new password:') db[name] = encodepass(passwd) else: print 'Wrong password!' def showmenu(): '''''程序运行的主函数''' fu = file('user.ini','r') db = pickle.load(fu) prompt = '''''(L)ogin Now (Q)uit (D)elet User (C)heck All User (R)eset Password Enter choice:''' done = False while not done: chosen = False while not chosen: try: choice = raw_input(prompt).split()[0].lower() except (EOFError,KeyboardInterrupt): choice = 'q' print '\nYou picked:[%s]' % choice if choice not in 'lqdcr': print 'invalid option,try again' else: chosen = True if choice == 'q':done = True if choice == 'l':olduser(db) if choice == 'd':deluser(db) if choice == 'c':checkuser(db) if choice == 'r':resetuser(db) fu = file('user.ini','w') pickle.dump(db,fu,True) fu.close() if __name__ == '__main__': '''''系统有一个用户名为admin 密码为admin的超级用户,请立即修改密码!''' print 'Welcome to User Information Management System!' Initialization('user.ini') Initialization('time.ini') showmenu()
看完了这篇文章,相信你对“python实现用户管理系统的方法”有了一定的了解,如果想了解更多相关知识,欢迎关注创新互联成都网站设计公司行业资讯频道,感谢各位的阅读!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
网站题目:python实现用户管理系统的方法-创新互联
当前链接:http://hbruida.cn/article/cscsge.html