Python模擬登錄成功與失敗處理方式(鏈接數(shù)據(jù)庫)

說明任務(wù)點:

1)用戶輸入用戶名帮非,如果沒有氧吐,用戶不能登錄;

2)如果用戶連續(xù)三次登錄密碼之間末盔,用戶會被鎖定一段時間筑舅;

3)在用戶被鎖定一段時間后,可以嘗試再次登錄陨舱;

程序使用庫:

datetime https://docs.python.org/2/library/datetime.html

pymysql http://pymysql.readthedocs.io/en/latest/index.html

數(shù)據(jù)庫設(shè)計如下:

數(shù)據(jù)庫數(shù)據(jù)形式如下

程序說明:

程序結(jié)構(gòu)為順序結(jié)構(gòu)翠拣,未涉及到函數(shù)的調(diào)用之類,只是為了練習(xí)使用pymysql 進行增刪該查的功能

整體思路如下:

(1) 鏈接數(shù)據(jù)庫

#創(chuàng)建數(shù)據(jù)庫的鏈接
connection = pymysql.connect(host='127.0.0.1',
                             port=3306,
                             user='root',
                             password='123456',
                             db='myschool',
                             charset='utf8',
                             cursorclass=pymysql.cursors.DictCursor)

(2) 交互輸入登陸用名名游盲,并根據(jù)輸入查詢數(shù)據(jù)庫數(shù)據(jù)

userName = input("輸入用戶名:")
        if "q"!=userName and "Q"!=userName:
                with connection.cursor() as cursor:
                    #根據(jù)用戶名查出用戶信息
                    sql = 'select * from t_user where name = %s'
                    result =  cursor.execute(sql,userName);

(3) 判斷輸入的用戶名是否存在心剥,如不存在則返回重新輸入,如存在則判斷是否被鎖定背桐,如果被鎖定還得判斷是否已經(jīng)過了鎖定時間

# 判斷是否存在此用戶
                    if 0==result:
                        print("無此用戶名存在优烧!")
                        continue
                    #獲取用戶信息
                    item = cursor.fetchone()
                    is_login = False
                    # 判斷用戶是否被禁
                    if item["is_based"]:
                        last_login_time = item["login_time"]
                        login_time = datetime.datetime.now()
                        waiting_time = int(((login_time-last_login_time).total_seconds())/60)
                        #用戶如果被禁,判斷還需要多長時間等待
                        if (waiting_time-3)<0:
                            print("賬號暫時鎖定链峭,請等待%d分鐘"%(3-waiting_time))
                            break

(4) 連續(xù)輸入三次畦娄,如果密碼輸入錯則被登錄失敗,否則登陸成功

times = 0
                    # 3次輸入密碼的機會
                    while times<3:
                        password = input("請輸入密碼:")
                        if password != item["password"]:
                            times += 1
                        else:
                            is_login = True
                            break

                    # 登錄成功與否,禁用信息以及登錄信息數(shù)據(jù)都在數(shù)據(jù)庫進行更新
                    if is_login:
                        is_based = 0
                        # 將datetime轉(zhuǎn)換字符串類型
                        login_time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
                        print("歡迎%s熙卡,登陸成功杖刷!"%(userName))
                    else:
                        is_based = 1
                        login_time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
                        print("登錄失敗,請等待10min")

(4) 更新數(shù)據(jù)庫的信息

# 更新數(shù)據(jù)庫的Mysql語句
                    sql = "update t_user set is_based = %d , login_time = '%s' where name='%s'"%(is_based,login_time,userName)
                    cursor.execute(sql)

                    # 由于對數(shù)據(jù)庫進行了更新驳癌,故需要提交事務(wù)
                    connection.commit()

全部代碼如下:

import pymysql
import datetime
'''
遇到不懂的問題滑燃?Python學(xué)習(xí)交流群:766545907滿足你的需求,資料都已經(jīng)上傳群文件颓鲜,可以自行下載表窘!
'''
#創(chuàng)建數(shù)據(jù)庫的鏈接
connection = pymysql.connect(host='127.0.0.1',
                             port=3306,
                             user='root',
                             password='123456',
                             db='myschool',
                             charset='utf8',
                             cursorclass=pymysql.cursors.DictCursor)
try:
    while True:
        userName = input("輸入用戶名:")
        if "q"!=userName and "Q"!=userName:
                with connection.cursor() as cursor:
                    #根據(jù)用戶名查出用戶信息
                    sql = 'select * from t_user where name = %s'
                    result =  cursor.execute(sql,userName);
                    # 判斷是否存在此用戶
                    if 0==result:
                        print("無此用戶名存在!")
                        continue
                    #獲取用戶信息
                    item = cursor.fetchone()
                    is_login = False
                    # 判斷用戶是否被禁
                    if item["is_based"]:
                        last_login_time = item["login_time"]
                        login_time = datetime.datetime.now()
                        waiting_time = int(((login_time-last_login_time).total_seconds())/60)
                        #用戶如果被禁甜滨,判斷還需要多長時間等待
                        if (waiting_time-3)<0:
                            print("賬號暫時鎖定乐严,請等待%d分鐘"%(3-waiting_time))
                            break

                    times = 0
                    # 3次輸入密碼的機會
                    while times<3:
                        password = input("請輸入密碼:")
                        if password != item["password"]:
                            times += 1
                        else:
                            is_login = True
                            break

                    # 登錄成功與否,禁用信息以及登錄信息數(shù)據(jù)都在數(shù)據(jù)庫進行更新
                    if is_login:
                        is_based = 0
                        # 將datetime轉(zhuǎn)換字符串類型
                        login_time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
                        print("歡迎%s衣摩,登陸成功昂验!"%(userName))
                    else:
                        is_based = 1
                        login_time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
                        print("登錄失敗,請等待10min")

                    # 更新數(shù)據(jù)庫的Mysql語句
                    sql = "update t_user set is_based = %d , login_time = '%s' where name='%s'"%(is_based,login_time,userName)
                    cursor.execute(sql)

                    # 由于對數(shù)據(jù)庫進行了更新艾扮,故需要提交事務(wù)
                    connection.commit()
                    break
        else:
            print("退出<惹佟!泡嘴!")
            break
finally:
    # 最終關(guān)閉鏈接
    connection.close();
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末甫恩,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子磕诊,更是在濱河造成了極大的恐慌填物,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件霎终,死亡現(xiàn)場離奇詭異滞磺,居然都是意外死亡,警方通過查閱死者的電腦和手機莱褒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門击困,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人广凸,你說我怎么就攤上這事阅茶。” “怎么了谅海?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵脸哀,是天一觀的道長。 經(jīng)常有香客問我扭吁,道長撞蜂,這世上最難降的妖魔是什么盲镶? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮蝌诡,結(jié)果婚禮上溉贿,老公的妹妹穿的比我還像新娘。我一直安慰自己浦旱,他們只是感情好宇色,可當我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著颁湖,像睡著了一般宣蠕。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上爷狈,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天植影,我揣著相機與錄音裳擎,去河邊找鬼涎永。 笑死,一個胖子當著我的面吹牛鹿响,可吹牛的內(nèi)容都是我干的羡微。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼惶我,長吁一口氣:“原來是場噩夢啊……” “哼妈倔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起绸贡,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤盯蝴,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后听怕,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體捧挺,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年尿瞭,在試婚紗的時候發(fā)現(xiàn)自己被綠了闽烙。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡声搁,死狀恐怖黑竞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情疏旨,我是刑警寧澤很魂,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站檐涝,受9級特大地震影響遏匆,放射性物質(zhì)發(fā)生泄漏霞玄。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一拉岁、第九天 我趴在偏房一處隱蔽的房頂上張望坷剧。 院中可真熱鬧,春花似錦喊暖、人聲如沸惫企。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽狞尔。三九已至,卻和暖如春巩掺,著一層夾襖步出監(jiān)牢的瞬間偏序,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工胖替, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留研儒,地道東北人。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓独令,卻偏偏與公主長得像端朵,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子燃箭,可洞房花燭夜當晚...
    茶點故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內(nèi)容