gpt4 book ai didi

python实现用户管理系统

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章python实现用户管理系统由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

本文实例为大家分享了python实现用户管理系统的具体代码,供大家参考,具体内容如下 。

《python核心编程》第七章练习题第五题 。

1、题目描述 。

 userpw2.py。下面的问题和例题7.1中的管理名字-密码的键值对数据程序有关.

(a) 修改那个脚本,使他能记录用户上次的登陆日期和时间(用time模块),并与用户密码一起保存起来。程序的界面要求用户输入用户名和密码的提示。无论用户名是否登陆成功,都应有提示,在用户登陆成功后,应更新相应用户的上次登陆时间戳。如果本次登陆与上次登陆在时间上相差不超过四个小时,则通知该用户:“You already in at :<last_login_timestamp>”.

(b) 添加一个管理菜单,其中有以下两项:(1)删除一个用户 (2)显示系统中所有用户的名字和他们密码的清单.

(c) 口令目前没有加密。请添加一段对口令加密的代码 。

(d) 为程序添加图形界面,例如,用Tkinter。(图形化界面开发比较复杂,这里没有用到。) 。

(e) 要求用户名布区分大小写.

(f ) 加强对用户名的限制,不允许符号和空白符.

(g) 合并“新用户”和“老用户”两个选项。如果一个新用户试图用一个不存在的用户名登陆,询问该用户是否是新用户,如果是肯定的,就创建该用户。否则按老用户的方式登陆.

2、程序中用到的模块,解释如下:

(1) re:正则表达式引擎,python中调用正则表达式的方法 。

(2) pickle:对象持久化,将数据写入到磁盘中 。

(3) datetime:时间处理,用于记录用户登陆时间戳 。

(4) base64:base64加密模块 。

(5) hashlib:hash加密模块  。

完整代码

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
#-*- 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:<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):
  '''''用户创建程序,由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()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.

原文链接:https://www.cnblogs.com/goback20170622/p/7197992.html 。

最后此篇关于python实现用户管理系统的文章就讲到这里了,如果你想了解更多关于python实现用户管理系统的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com