python實(shí)現(xiàn)用戶管理系統(tǒng)
本文實(shí)例為大家分享了python實(shí)現(xiàn)用戶管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
《python核心編程》第七章練習(xí)題第五題
一、題目描述
userpw2.py。下面的問題和例題7.1中的管理名字-密碼的鍵值對數(shù)據(jù)程序有關(guān)。
(a) 修改那個腳本,使他能記錄用戶上次的登陸日期和時間(用time模塊),并與用戶密碼一起保存起來。程序的界面要求用戶輸入用戶名和密碼的提示。無論用戶名是否登陸成功,都應(yīng)有提示,在用戶登陸成功后,應(yīng)更新相應(yīng)用戶的上次登陸時間戳。如果本次登陸與上次登陸在時間上相差不超過四個小時,則通知該用戶:“You already in at :<last_login_timestamp>”。
(b) 添加一個管理菜單,其中有以下兩項(xiàng):(1)刪除一個用戶 (2)顯示系統(tǒng)中所有用戶的名字和他們密碼的清單。
(c) 口令目前沒有加密。請?zhí)砑右欢螌诹罴用艿拇a
(d) 為程序添加圖形界面,例如,用Tkinter。(圖形化界面開發(fā)比較復(fù)雜,這里沒有用到。)
(e) 要求用戶名布區(qū)分大小寫。
(f ) 加強(qiáng)對用戶名的限制,不允許符號和空白符。
(g) 合并“新用戶”和“老用戶”兩個選項(xiàng)。如果一個新用戶試圖用一個不存在的用戶名登陸,詢問該用戶是否是新用戶,如果是肯定的,就創(chuàng)建該用戶。否則按老用戶的方式登陸。
二、程序中用到的模塊,解釋如下:
(1) re:正則表達(dá)式引擎,python中調(diào)用正則表達(dá)式的方法
(2) pickle:對象持久化,將數(shù)據(jù)寫入到磁盤中
(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): '''''程序初始化,創(chuàng)建user.ini和time.ini文件''' dict_test={'admin':'db69fc039dcbd2962cb4d28f5891aae1'} #創(chuàng)建超級管理員,默認(rèn)密碼為admin f = file(file_name,'a+') #以追加的方式打開文件,避免文件被修改 if len(f.readlines()) ==0: #判斷程序是否為空,只在第一次運(yùn)行的時候初始化 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): '''''記錄用戶登陸時間,結(jié)果保存在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:<last_login_timestamp>' except: print 'You already logged in at:<last_login_timestamp>' dbt[user] = datetime.today() ft = file('time.ini','w') pickle.dump(dbt, ft, True) ft.close() def newuser(db): '''''用戶創(chuàng)建程序,由olduser調(diào)用''' while True: name = raw_input('Please input the username:') if re.match(r'\w', name): #采用正則表達(dá)式檢測用戶名是否合法 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(): '''''程序運(yùn)行的主函數(shù)''' 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__': '''''系統(tǒng)有一個用戶名為admin 密碼為admin的超級用戶,請立即修改密碼!''' print 'Welcome to User Information Management System!' Initialization('user.ini') Initialization('time.ini') showmenu()
更多學(xué)習(xí)資料請關(guān)注專題《管理系統(tǒng)開發(fā)》。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
DRF跨域后端解決之django-cors-headers的使用
這篇文章主要介紹了DRF跨域后端解決之django-cors-headers的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01詳解python 拆包可迭代數(shù)據(jù)如tuple, list
拆包是指將一個結(jié)構(gòu)中的數(shù)據(jù)拆分為多個單獨(dú)變量中。下面通過本文給大家介紹python 拆包可迭代數(shù)據(jù)如tuple, list的相關(guān)資料,需要的朋友參考下吧2017-12-12Python基礎(chǔ)總結(jié)之itertools模塊詳解
itertools模塊是Python中一個鮮為人知但功能強(qiáng)大的工具,它專注于高效、內(nèi)存友好的迭代器操作,使其成為處理大型或復(fù)雜數(shù)據(jù)集的理想選擇,今天我們一起探討Python標(biāo)準(zhǔn)庫中的一個隱藏的寶藏:itertools模塊,感興趣的朋友一起看看吧2024-06-06Django Form 實(shí)時從數(shù)據(jù)庫中獲取數(shù)據(jù)的操作方法
這篇文章主要介紹了Django Form 實(shí)時從數(shù)據(jù)庫中獲取數(shù)據(jù)的相關(guān)知識,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-07-07Python 3.x 連接數(shù)據(jù)庫示例(pymysql 方式)
這篇文章主要介紹了Python 3.x 連接數(shù)據(jù)庫示例(pymysql 方式),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01Python中定時任務(wù)框架APScheduler的快速入門指南
APScheduler是基于Quartz的一個Python定時任務(wù)框架,實(shí)現(xiàn)了Quartz的所有功能,使用起來十分方便。下面這篇文章主要跟大家介紹了Python中定時任務(wù)框架APScheduler的快速入門指南,需要的朋友可以參考借鑒,下面來一起看看吧。2017-07-07Python實(shí)現(xiàn)的根據(jù)IP地址計算子網(wǎng)掩碼位數(shù)功能示例
這篇文章主要介紹了Python實(shí)現(xiàn)的根據(jù)IP地址計算子網(wǎng)掩碼位數(shù)功能,涉及Python數(shù)值運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2018-05-05