要求:

1、用户在登录之前要判断密码文件是否已经是锁定状态,如果是提示不让登录

2、登录用户密码输入错误3次,就锁定改用户,并更新文件内容

3、登录正确,提示欢迎登录信息

data.txt 文件内容:

root:aaa:0

adm:bbb:1

ops:ccc:3

以冒号分割,用户名:密码:用户对应的状态(3表示改用户被锁定)

 

代码:

 #!/usr/bin/env python3
 # -*- coding: utf-8 -*-

 import os,sys,getpass          # getpass是输入密码的时候不显示输入的内容,和Linux命令终端输入密码时一样
 os.system('cls')

 u = 0
 while u < 3:     # 如果用户3次输入的用户名都是错误就有问题,不然再输入了
     username = input('请输入用户名:')
     user_f = open('data.txt', 'r')      # 以读方式打开
     user_str = user_f.read()      # 读取文件所有内容
     user_f.close()
     user_info = user_str.strip().split('\n')     # 去掉空且以换行符作为分割生产列表  ['root:aaa:3', 'adm:bbb:1', 'ops:ccc:3']
     user_list = []
     for user_line in user_info:
         user_tmp = user_line.split(':')      # 再以冒号分割生成子列表,这种样子格式['root', 'aaa', '3']
         user_list.append(user_tmp)      # 这里的内容就是  [['root', 'aaa', '3'], ['adm', 'bbb', '1'], ['ops', 'ccc', '3']]
     print(user_list)
     for user_one in user_list:
         if username == user_one[0] and int(user_one[-1]) == 3:    # 看输入的用户是不是已经是锁定状态(data.txt文件的第3列如果是3就表示之前连续输错3次)
             print('用户 %s 已经锁定,请联系您的系统管理员!' % username)
             sys.exit(1)
     for user_one in user_list:
         if username == user_one[0]:    # 判断输入的用户名是不是在文件中,条件成立往下执行
             p = 0    # 初始化密码计数器
             while p < 3:
                 passwd = input('请输入密码:')
                 if passwd == user_one[1]:    # 前面用户名已经判断了,这里只需要判断密码是不是正确的就行
                     print('欢迎登陆!')
                     sys.exit(0)
                 else:
                     if p != 2:
                         print('对不起,%s 的密码错误,您还有 %d 次机会!' % (username, 2 - p))
                     p += 1   # 能执行到这一步说明密码输错了,计数器 +1
             else:
                 user_one[2] = 3    # 如果用户连续3次输入错密码就要更新这个用户对应的密码记录,并锁定用户
                 user_f = open('data.txt', 'w')
                 for user_info2 in user_list:
                     user_f.write(user_info2[0] + ':' + user_info2[1] + ':' + str(user_info2[2]) + '\n')   # 把当前的值更新到文件中
                 user_f.close()
                 sys.exit('对不起,%s 用户已被锁定,请联系管理员!' % username)
         else:
             pass
     else:
         if u != 2:
             print('对不起,您输入的用户 %s 不存在,您还有 %d 机会。' % (username, 2-u))
     u += 1
 else:
     sys.exit('用户输入错误3次,程序已退出。')

程序运行效果:

请输入用户名:root
[['root', 'aaa', '2'], ['adm', 'bbb', '1'], ['ops', 'ccc', '3']]   # 从文件读取出来转换成列表形式,这里打印出来是方便实验
请输入密码:11
对不起,root 的密码错误,您还有 2 次机会!
请输入密码:11
对不起,root 的密码错误,您还有 1 次机会!
请输入密码:11
对不起,root 用户已被锁定,请联系管理员!

此时data.txt文件内容的root用户登录次数已更新到 3 ,再次登录 root 提示被锁定

请输入用户名:root
[['root', 'aaa', '3'], ['adm', 'bbb', '1'], ['ops', 'ccc', '3']]
用户 root 已经锁定,请联系您的系统管理员!

正常登录:

请输入用户名:adm
[['root', 'aaa', '3'], ['adm', 'bbb', '1'], ['ops', 'ccc', '3']]
请输入密码:bbb
欢迎登陆!

原文:http://www.cnblogs.com/brianzhu/articles/6282905.html

python 用户登录的更多相关文章

  1. python用户登录,密码错误3次则锁定

    需求: 1.输入用户名密码 2.认证成功后显示欢迎信息 3.输错三次后锁定 实现思路: 1.判断用户是否在黑名单,如果在黑名单提示账号锁定. 2.判断用户是否存在,如果不存在提示账号不存在. 3.判断 ...

  2. 第三篇python用户登录程序实现

    需求: 1.通过注册输入用户名和密码 2.能够验证用户名和密码是否正确 3.限制输入一定错误次数后退出程序 4.利用格式化输出方式输出信息 分析: 使用username=input()和passwor ...

  3. python 初学习 模拟用户登录

    #!/usr/bin/env python#coding:utf-8''' 2017年8月19日 模拟用户登录,userfile 文件保存字典 用户名,和密码 sorryname 文件保存字典 登录过 ...

  4. Python程序练习1-模拟用户登录验证

    1.功能简介 此程序模拟用户登录验证的过程,实现用户名输入.黑名单检测.用户有效性判别.密码输入及验证等.用户在3次以内输入正确密码登陆成功,连续输错3次密码登陆失败,且该用户名被记录在黑名单,黑名单 ...

  5. python 全栈开发,Day119(Flask初识,Render Redirect HttpResponse,request,模板语言 Jinja2,用户登录例子,内置Session)

    一.Flask初识 首先,要看你学没学过Django 如果学过Django 的同学,请从头看到尾,如果没有学过Django的同学,并且不想学习Django的同学,轻饶过第一部分 三大主流Web框架对比 ...

  6. Python之简单的用户登录和注册

    # -*- coding: utf-8 -*- # @Time : 2018/7/26 20:16 # @Author : Adam # @File : exam2.py # @Project: ke ...

  7. Python练习-有点儿意思的用户登录

    Alex大神的需求(说实话他需求真特么多,真难满足他): 编写一个用户登陆接口:输入用户名密码,认证成功后显示欢迎信息,输错三次后锁定; # 编辑者:闫龙 #用户登录功能输入3次以上会被锁定:为了方便 ...

  8. python实现用户登录问候

    创建一个至少包含 5个用户名的列表,且其中一个用户名为 'admin' .想象你要编写代码,在每位用户登录网站后都打印一条问候消息.遍历用户名列表,并向每位用户打印一条问候消息.添加一条 if 语句, ...

  9. Python阶段复习 - part 4 - 用户登录程序

    简易版: #!/usr/bin/env python # _*_ coding:UTF-8 _*_ # __auth__:Dahlhin import sys userinfo = r'userinf ...

随机推荐

  1. NPOI+反射 实现快速导出

    只是觉得这样很方便 记录一下 公司有封装的方法,不过是查出的Table类型,每次用的时候很都很烦,处理数据也不方便,最主要的是我也没耐心去看,反正在我看来很麻烦,用的时候很头疼.还是习惯通过Model ...

  2. Linux服务器下对Oracle作Rman备份

    由于工作需要,最近要对几台Linux系统下的Oracle数据库进行Rman备份,就在操作的同时,整理了一下,方便今后作为资料进行查阅. ------------------------Linux服务器 ...

  3. 如何给Ionic写一个cordova插件

    写一个cordova插件 之前由javaWeb转html5开发,由于面临新技术,遂在适应的过程中极为挣扎,不过还好~,这个过程也极为短暂:现如今面临一些较为复杂的需求还会有一丝丝头痛,却没有一开始那么 ...

  4. C++第四篇--重载_指针_引用

    C++第四篇--重载_指针_引用 1. 基础知识 重载:函数名相同,根据参数不同(类型.数量.顺序不同)调用同名函数 指针和引用:引用就是别名,引用时必须初始化,引用你定义的变量. int a; in ...

  5. web前端开发面试题(未完待续)

    一.HTML与XHTML的不同:1)XHTML元素必须被正确地嵌套 2)元素必须被关闭   如:<h1>--</h1>关闭 3)标签名必须用小写字母 4)XHTML文档必须有根 ...

  6. 第五章之S5PV210将u-boot.bin从SD卡中搬到DDR中

    1,在完成上一节的memory初始化后,接下来在arch/arm/cpu/armv7/start.S的160行:如下图 2,跳转到arch/arm/lib/board.c下的board_init_f函 ...

  7. cn_office2016

    office 2016是可用激活器激活的,但是激活office 365就有点困难了. 附上office 2016下载地址:http://pan.baidu.com/s/1pLTqPyr 破解机:htt ...

  8. 枪战Maf[POI2008]

    题目描述 有n个人,每个人手里有一把手枪.一开始所有人都选定一个人瞄准(有可能瞄准自己).然后他们按某个顺序开枪,且任意时刻只有一个人开枪.因此,对于不同的开枪顺序,最后死的人也不同. 输入 输入n人 ...

  9. metasploit快速入门

    今天没上班,在小黑屋里看了一个一百多页的书<metasploit新手指南>,在此将笔记分享给大家.欢迎大家批评指正,共同学习进步.     metasploit新手指南 笔记 kali 0 ...

  10. git分支管理之创建与合并分支

    在版本回退里,你已经知道,每次提交,Git都把它们串成一条时间线,这条时间线就是一个分支.截止到目前,只有一条时间线,在Git里,这个分支叫主分支,即master分支.HEAD严格来说不是指向提交,而 ...