Python模擬用戶登錄驗證
本文實例為大家分享了Python模擬用戶登錄驗證的具體代碼,供大家參考,具體內(nèi)容如下
1.功能簡介
此程序模擬用戶登錄驗證的過程,實現(xiàn)用戶名輸入、黑名單檢測、用戶有效性判別、密碼輸入及驗證等。用戶在3次以內(nèi)輸入正確密碼登陸成功,連續(xù)輸錯3次密碼登陸失敗,且該用戶名被記錄在黑名單,黑名單中的用戶被鎖定不能再登陸。
2.實現(xiàn)方法
本程序采用python語言編寫,將各項任務(wù)進行分解并用定義對應(yīng)的函數(shù)來處理,從而使程序結(jié)構(gòu)清晰,易于維護。主要編寫了四個函數(shù):
login() #登陸函數(shù),為主函數(shù),完成用戶名檢測和密碼驗證
inquire_blacklist(name) #查詢用戶名是否在黑名單中
inquire_userlist(name) #查詢用戶名是否在用戶名單中,并返回密碼或None
add_blacklist(name) #添加用戶名到黑名單文件
函數(shù)調(diào)用框架:運行l(wèi)ogin()-->輸入用戶名-->調(diào)用inquire_blacklist(name)進行黑名單檢測-->調(diào)用inquire_userlist(name)進行用戶名有效性判別,有效則返回用戶密碼,再與輸入密碼對比驗證-->連續(xù)輸錯3次密碼則調(diào)用add_blacklist(name)添加用戶到黑名單。
3.流程圖

4.代碼
# Author:Byron Li
import os
BASE_DIR = os.path.dirname(__file__) #獲取文件目錄路徑
userlist='userlist.txt' #存取已注冊用戶名單文件,包括用戶名和密碼
blacklist='blacklist.txt' #存取鎖定用戶的黑名單文件
userlist_path = os.path.join(BASE_DIR,userlist) #注冊用戶名單文件路徑
blacklist_path = os.path.join(BASE_DIR,blacklist) #黑名單文件路徑
#---------------------------登陸函數(shù)(主函數(shù))--------------------------
def login(): #登陸函數(shù)
username = input("請輸入用戶名:")
while(True):
if inquire_blacklist(username): #查詢輸入用戶名是否在黑名單中
print("不好意思,此用戶名\"%s\"已被鎖定,禁止登陸!"%username)
return False
else:
user_password = inquire_userlist(username) #查詢輸入用戶名是否存在注冊用戶名單中,若存在則返回該用戶密碼
if user_password:
for i in range(3):
password = input("請輸入密碼:") if i==0 else input("密碼輸入錯誤,請重新輸入密碼:")
if password==user_password:
print('歡迎%s登陸!'%username)
return True
else:
print("您已經(jīng)連續(xù)輸錯密碼3次,用戶名將被鎖定,禁止再登陸!")
add_blacklist(username) #添加用戶名到黑名單文件
return False
else:
username = input('無效的用戶名,請重新輸入:')
# ------------------------------------------------------------
#-----------------查詢黑名單函數(shù)-------------------------------
def inquire_blacklist(name): #查詢用戶名是否在黑名單中
with open(blacklist_path, 'r') as f:
for line in f:
if name==line.strip():
return True
return False
# -------------------------------------------------------------
#-----------------------查詢用戶名函數(shù)--------------------------
def inquire_userlist(name): #查詢用戶名是否在注冊用戶名單中
with open(userlist_path, 'r') as f:
for line in f:
[username,password] = line.split()
if name==username:
return password
return None
# ------------------------------------------------------------
#-----------------------------添加黑名單函數(shù)--------------------
def add_blacklist(name): #添加用戶名到黑名單文件
with open(blacklist_path, 'a') as f:
f.write(str(name)+'\n')
return True
# ------------------------------------------------------------------------------
if login(): #執(zhí)行登陸函數(shù)
print('登陸成功!'.center(47,'*'))
else:
print('登陸失??!'.center(47,'*'))
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Python的Flask框架中實現(xiàn)登錄用戶的個人資料和頭像的教程
- python實現(xiàn)用戶登錄系統(tǒng)
- Python 用戶登錄驗證的小例子
- python3.0 模擬用戶登錄,三次錯誤鎖定的實例
- Python實現(xiàn)的用戶登錄系統(tǒng)功能示例
- python初學(xué)之用戶登錄的實現(xiàn)過程(實例講解)
- 詳解Python用戶登錄接口的方法
- python實現(xiàn)根據(jù)用戶輸入從電影網(wǎng)站獲取影片信息的方法
- 使用python實現(xiàn)生成用戶信息
- python-itchat 獲取微信群用戶信息的實例
- python實現(xiàn)得到當前登錄用戶信息的方法
相關(guān)文章
關(guān)于python中密碼加鹽的學(xué)習(xí)體會小結(jié)
這篇文章主要介紹了關(guān)于python中密碼加鹽的學(xué)習(xí)體會小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
基于Python中request請求得到的response的屬性問題
這篇文章主要介紹了基于Python中request請求得到的response的屬性問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-05-05
Pandas:DataFrame對象的基礎(chǔ)操作方法
今天小編就為大家分享一篇Pandas:DataFrame對象的基礎(chǔ)操作方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
langchain使用自定義example?selector示例解析
這篇文章主要為大家介紹了langchain使用自定義example?selector示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08

