python实现用户管理系统


Posted in Python onJanuary 10, 2018

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

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

一、题目描述

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

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

(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:<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()

更多学习资料请关注专题《管理系统开发》。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python实现将汉字转换成汉语拼音的库
May 05 Python
Python中if __name__ == '__main__'作用解析
Jun 29 Python
python获取外网ip地址的方法总结
Jul 02 Python
Python进度条实时显示处理进度的示例代码
Jan 30 Python
使用Numpy读取CSV文件,并进行行列删除的操作方法
Jul 04 Python
用Python实现大文本文件切割的方法
Jan 12 Python
在Python中构建增广矩阵的实现方法
Jul 01 Python
pandas 时间格式转换的实现
Jul 06 Python
JupyterNotebook设置Python环境的方法步骤
Dec 03 Python
使用python的pyplot绘制函数实例
Feb 13 Python
python 使用xlsxwriter循环向excel中插入数据和图片的操作
Jan 01 Python
在 Golang 中实现 Cache::remember 方法详解
Mar 30 Python
python的Tqdm模块的使用
Jan 10 #Python
python3.6 实现AES加密的示例(pyCryptodome)
Jan 10 #Python
Python设计模式之MVC模式简单示例
Jan 10 #Python
Python设计模式之命令模式简单示例
Jan 10 #Python
Python爬虫实例_利用百度地图API批量获取城市所有的POI点
Jan 10 #Python
Python之多线程爬虫抓取网页图片的示例代码
Jan 10 #Python
Python设计模式之观察者模式简单示例
Jan 10 #Python
You might like
BBS(php &amp; mysql)完整版(五)
2006/10/09 PHP
PHP 一个比较完善的简单文件上传
2010/03/25 PHP
解析PHP汉字转换拼音的类
2013/06/18 PHP
PHPMailer的主要功能特点和简单使用说明
2014/02/17 PHP
CodeIgniter控制器之业务逻辑实例分析
2016/01/20 PHP
根据key删除数组中指定的元素实现方法
2017/03/02 PHP
Javascript 类型转换方法
2010/10/24 Javascript
Jquery 表单验证类介绍与实例
2013/06/09 Javascript
基于jquery编写的横向自适应幻灯片切换特效的实例代码
2013/08/06 Javascript
JavaScript判断数字是否为质数的方法汇总
2016/06/02 Javascript
总结AngularJS开发者最常犯的十个错误
2016/08/31 Javascript
jq checkbox 的全选并ajax传参的实例
2017/04/01 Javascript
jQuery插件select2利用ajax高效查询大数据列表(可搜索、可分页)
2017/05/19 jQuery
ES6中数组array新增方法实例总结
2017/11/07 Javascript
angular实现页面打印局部功能的思考与方法
2018/04/13 Javascript
微信小程序之swiper滑动面板用法示例
2018/12/04 Javascript
分享一个vue项目“脚手架”项目的实现步骤
2019/05/26 Javascript
Node.js HTTP服务器中的文件、图片上传的方法
2019/09/23 Javascript
layui--select使用以及下拉框实现键盘选择的例子
2019/09/24 Javascript
vue循环中点击选中再点击取消(单选)的实现
2020/09/10 Javascript
vue项目中使用rem,在入口文件添加内容操作
2020/11/11 Javascript
python利用datetime模块计算时间差
2015/08/04 Python
两个使用Python脚本操作文件的小示例分享
2015/08/27 Python
Python实现变量数值交换及判断数组是否含有某个元素的方法
2017/09/18 Python
Python快速排序算法实例分析
2017/11/29 Python
python3使用print打印带颜色的字符串代码实例
2019/08/22 Python
Python3如何对urllib和urllib2进行重构
2019/11/25 Python
python操作cfg配置文件方式
2019/12/22 Python
CSS3用@font-face实现自定义英文字体
2013/09/23 HTML / CSS
HTML5中视频音频的使用详解
2017/07/07 HTML / CSS
如何给HTML标签中的文本设置修饰线
2019/11/18 HTML / CSS
Joie官方网上商店:购买服装和女装配饰
2018/06/05 全球购物
美国排名第一的葡萄酒俱乐部:Firstleaf Wine Club
2020/01/02 全球购物
小学教师学期末自我评价
2013/09/25 职场文书
个人四风问题对照检查材料
2014/10/01 职场文书
人民币使用说明书
2019/04/17 职场文书