濮阳杆衣贸易有限公司

主頁 > 知識庫 > Python實現用戶登錄并且輸入錯誤三次后鎖定該用戶

Python實現用戶登錄并且輸入錯誤三次后鎖定該用戶

熱門標簽:合肥阿里辦理400電話號 高德地圖標注公司位置需要錢嗎 襄陽外呼增值業(yè)務線路解決方案 地圖標注資源分享注冊 怎么去掉地圖標注文字 廊坊地圖標注申請入口 慶陽外呼系統(tǒng)定制開發(fā) 北京外呼系統(tǒng)咨詢電話 海南人工外呼系統(tǒng)哪家好

實現用戶登錄并且輸入錯誤三次后鎖定該用戶

我的測試環(huán)境,win7,python3.5.1

提示輸入用戶名,和密碼

判斷是否被鎖定

判斷用戶名和密碼是否匹配

輸入錯誤三次,賬號被鎖定

思路

代碼塊

name = 'alex'   #正確的用戶名
passwd = '123456'  #正確的密碼
lock_usr = []   #鎖定賬號列表

for i in range(0,3):
 usr_name = input("用戶名:")
 usr_passwd = input("密碼:")
 if usr_name == name and usr_passwd == passwd:
  print("玩命加載中...")
  break
 elif name != usr_name or passwd != usr_passwd:
  if i  2:
   print("用戶名密碼錯誤,請重新輸入!")
  else:
   lock_usr.append(usr_name)     #將輸入錯誤三次的的賬號添加到鎖定列表中
   print("對不起!機會只有三次,您的賬號密碼被鎖定")
 elif usr_name in lock_usr:
  print("該賬號已鎖定,請解鎖后登陸")

PS:下面在通過c#實現密碼輸入三次錯誤后鎖定用戶功能

#region 密碼輸入三次錯誤后鎖定用戶功能
  #region 增加錯誤次數的方法
  ///summary>
  ///增加錯誤次數的方法
  ////summary>
  private void IncErrorTime()
  {
   string ConnStr = ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString;
   using (SqlConnection conn = new SqlConnection(ConnStr))
   {
    using (SqlCommand updateCmd = conn.CreateCommand())
    {
     updateCmd.CommandText = "update T_Admin set errortime=errortime+1 whereUsername=@username";
     updateCmd.Parameters.Add(new SqlParameter("username", cmbuserName.Text));
     conn.Open();
     updateCmd.ExecuteNonQuery();
    }
   }
  } 
  #endregion
  #region 錯誤次數清0
  ///summary>
  ///錯誤次數清0
  ////summary>
  private void NotErrorTime()
  {
   string ConnStr = ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString;
   using (SqlConnection conn = new SqlConnection(ConnStr))
   {
    using (SqlCommand updateCmd = conn.CreateCommand())
    {
     updateCmd.CommandText = "update T_Admin set errortime=0 whereUsername=@username";
     updateCmd.Parameters.Add(new SqlParameter("username", cmbuserName.Text));
     conn.Open();
     updateCmd.ExecuteNonQuery();
    }
   }
  } 
  #endregion
  #region 密碼錯誤3次,記錄當前時間加30分鐘
  ///summary>
  ///密碼錯誤3次,記錄當前時間加30分鐘
  ////summary>
  private void IncLoginTime()
  {
   string ConnStr = ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString;
   using (SqlConnection conn = new SqlConnection(ConnStr))
   {
    using (SqlCommand updateCmd = conn.CreateCommand())
    {
     updateCmd.CommandText = "update T_Admin set logintime=@logintime whereUsername=@username";
     DateTime logintime = DateTime.Now.AddMinutes(30);
     updateCmd.Parameters.Add(new SqlParameter("username", cmbuserName.Text));
     updateCmd.Parameters.Add(new SqlParameter("logintime", logintime.ToString()));
     conn.Open();
     updateCmd.ExecuteNonQuery();
    }
   }
  } 
  #endregion
  #region 按鈕事件判斷用戶登錄3次失效后鎖定用戶30分鐘
  private void BtnClike()
  {
   string username = cmbuserName.Text;
   string password = txtPwd.Text;
   string ConnStr = ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString;
   using (SqlConnection conn = new SqlConnection(ConnStr))
   {
    using (SqlCommand cmd = conn.CreateCommand())
    {
     cmd.CommandText = "select * from T_Admin whereusername=@username";
     cmd.Parameters.Add(new SqlParameter("username", username));
     conn.Open();
     using (SqlDataReader reader = cmd.ExecuteReader())
     {
      if (reader.Read())
      {
       //用戶存在
       string dbpassword = reader.GetString(reader.GetOrdinal("password"));
       DateTime logintime = reader.GetDateTime(reader.GetOrdinal("logintime"));
       //判斷當前時間是是服務器允許登錄時間
       if (logintime > DateTime.Now)
       {
        MessageBox.Show("一定時間內禁止登錄");
        return;
       }
       //如果密碼正確
       if (dbpassword == txtPwd.Text)
       {
        NotErrorTime();
        MessageBox.Show("登錄成功!");
       }
       //如果密碼錯誤
       else
       {
        int errortime = reader.GetInt32(reader.GetOrdinal("errortime"));
        if (errortime >= 2)
        {
         MessageBox.Show("密碼錯誤次數太多!");
         IncLoginTime();
         NotErrorTime();
         return;
        }
        MessageBox.Show("密碼錯誤!");
        IncErrorTime();//密碼錯誤,次數加1
       }
      }
      else//用戶名不存在
      {
       MessageBox.Show("用戶名不存在!");
       return;
      }
     }
    }
   }
  }
  #endregion
  #endregion

總結

以上所述是小編給大家介紹的Python實現用戶登錄并且輸入錯誤三次后鎖定該用戶,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

您可能感興趣的文章:
  • python實現校園網自動登錄的示例講解
  • python爬蟲_實現校園網自動重連腳本的教程
  • Python制作一個仿QQ辦公版的圖形登錄界面
  • Python自動登錄QQ的實現示例
  • Python爬蟲實現自動登錄、簽到功能的代碼
  • python 識別登錄驗證碼圖片功能的實現代碼(完整代碼)
  • Python 實現自動登錄+點擊+滑動驗證功能
  • Python +Selenium解決圖片驗證碼登錄或注冊問題(推薦)
  • Python GUI自動化實現繞過驗證碼登錄
  • 利用Python優(yōu)雅的登錄校園網

標簽:哈密 臺州 鶴崗 鎮(zhèn)江 平頂山 株洲 綿陽 商丘

巨人網絡通訊聲明:本文標題《Python實現用戶登錄并且輸入錯誤三次后鎖定該用戶》,本文關鍵詞  Python,實現,用戶,登錄,并且,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python實現用戶登錄并且輸入錯誤三次后鎖定該用戶》相關的同類信息!
  • 本頁收集關于Python實現用戶登錄并且輸入錯誤三次后鎖定該用戶的相關信息資訊供網民參考!
  • 推薦文章
    玉林市| 米脂县| 肇东市| 明光市| 郯城县| 洪雅县| 闸北区| 永登县| 监利县| 绥滨县| 车致| 枝江市| 荃湾区| 皮山县| 镇平县| 白沙| 鄂托克旗| 韶山市| 阜城县| 太康县| 江川县| 会宁县| 达日县| 桦甸市| 藁城市| 新平| 三江| 海丰县| 靖远县| 米易县| 新昌县| 禄劝| 巩义市| 高阳县| 天等县| 二连浩特市| 沈阳市| 林州市| 株洲县| 类乌齐县| 台州市|