WinForm登錄驗證

来源:https://www.cnblogs.com/fenqinearl/archive/2018/12/10/10099670.html
-Advertisement-
Play Games

概述:輸錯三次禁止登陸,15分鐘後才能繼續。圖示:Form1代碼:using System;using System.Configuration;using System.Data.SqlClient;using System.Windows.Forms;namespace 登錄驗證項目{ publ... ...


概述:輸錯三次禁止登陸,15分鐘後才能繼續。

圖示:

image

Form1代碼:

using System;
using System.Configuration;
using System.Data.SqlClient;
using System.Windows.Forms;

namespace 登錄驗證項目
{
     public partial class Form1 : Form
     {
         public Form1()
         {
             InitializeComponent();
         }

        private void button1_Click(object sender, EventArgs e)
         {
             //連接資料庫
             //將連接字元串寫入配置文件中 string connStr = "sever=.;uid=sa;pwd=123456;database=demo";

這部分寫在配置文件中

//<connectionStrings>
   // <add name="SqlConn" connectionString="server=.;uid=sa;pwd=123456;database=LoginBlock"/>
  //</connectionStrings>


             //條添加引用引入configuration命名空間
             string connStr = ConfigurationManager.ConnectionStrings["SqlConn"].ConnectionString;
             using (SqlConnection conn = new SqlConnection(connStr))
             {
                 using (SqlCommand cmd = conn.CreateCommand())
                 {

                    conn.Open();
                     //select 查詢語句str
                     string str = @"SELECT  [Uid]
                                               ,[Unm]
                                               ,[Pwd]
                                               ,[ErrorDate]
                                               ,[ErrorTimes]
                                           FROM [Login_Block]
                                           WHERE Unm='" + textBox1.Text.Trim()
                                           + "' and Pwd='" + textBox2.Text.Trim() + "' ";
                     cmd.CommandText = str;
                     // bool ishasdata=false;

//這裡創建Login對象


                     Login login = null;
                     using (SqlDataReader reader = cmd.ExecuteReader())
                     {//判斷是否有數據
                         #region MyRegion
                         //if (!reader.hasrows)
                         //{
                         //    //修改錯誤時間,錯誤次數

                        //}
                         #endregion
                         #region MyRegion
                         if (reader.HasRows)
                         {
                             reader.Read();
                         }
                         #endregion
                         if (reader.Read())
                         {
                             login = new Login();
                             login.Uid = int.Parse(reader["Uid"].ToString());
                             login.Pwd = reader["Pwd"].ToString();
                             login.ErrorTimes = int.Parse(reader["ErrorTimes"].ToString());
                             login.Errordata = DateTime.Parse(reader["Errordate"].ToString());
                         }
                         // ishasdata = reader.HasRows;


                     }//花括弧執行結束之前reader對象一直占用conn對象
                     if (login == null/*!ishasdata*/)
                     {
                         //修改 錯誤時間,錯誤次數  where UserName=txtUserName.Text
                         cmd.CommandText =
                             "update Login_Block set Errordate=getdate(), ErrorTimes=ErrorTimes+1 where Unm='" +
                             textBox1.Text.Trim() + "'";
                         cmd.ExecuteNonQuery();
                         //MessageBox.Show("用戶名密碼Error");
                         return;
                     }
                     //執行有數據的過程
                     if (login.ErrorTimes < 3 || DateTime.Now.Subtract(login.Errordata).Minutes > 15)
                     {
                         MessageBox.Show("登錄成功!!");
                         cmd.CommandText = "update Login_Block set ErrorTimes=0,Errordate=getdate() where Uid=" + login.Uid;
                         cmd.ExecuteNonQuery();
                     }
                     else
                     {
                         MessageBox.Show("登錄失敗!賬號被鎖定");
                     }
                 }
             }
         }
     }
}

Login類:

using System;

namespace 登錄驗證項目
{
     public class Login
     {
         //[Uid],[Pwd],[ErrorTimes],[Errordata]
         public int Uid { get; set; }
         public string Unm { get; set; }
         public string Pwd { get; set; }
         public int ErrorTimes { get; set; }
         public DateTime Errordata { get; set; }
     }
}

資料庫:

表:Login_Block

欄位:

[Uid]                                       

[Unm]                                       

[Pwd]                                      

[ErrorDate]                                           

[ErrorTimes]


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、predicate註冊過程 今天我們來聊聊predicate函數是怎麼被註冊進去的,也就是要執行的一堆predicate是怎麼成為“選中的孩子”。 代碼位置:pkg/scheduler/factory/plugins.go:111 這個函數註冊一個predicate函數,返回predicate名 ...
  • 首先去阿裡雲申請一個pfx證書,可以免費獲得。 其次,在tomcat的server.xml增加如下connector <Connector port="443" protocol="org.apache.coyote.http11.Http11NioProtocol" maxThreads="150 ...
  • 垃圾收集器 手機演算法是記憶體回收的方法論,垃圾收集器是記憶體回收的具體實現。 並行:指多條垃圾收集線程並行工作,但此時用戶線程仍然處於等待狀態 併發:值用戶線程與垃圾收集線程同時執行(但並不一定是並行的),用戶程式在繼續運行,而垃圾收集程式運行於另一個CPU上。 Serial收集器 單線程收集器,也就是 ...
  • 第一類對象 函數對象對象可以像變數一樣進行賦值 還可以作為列表的元素進行使用 可以作為返回值返回 可以作為參數進行傳遞 閉包 閉包(函數的嵌套) 內層函數對外層函數中的變數的使用 好處: 1. 保護變數不被侵害 2. 讓一個變數常駐記憶體 如何通過代碼查看一個閉包 __closure__: 有東西就是 ...
  • 有一個字元串 “aaddfdfdercfghfyttefsfsfewretr123trefg5624sdfcgvfdgte6435234532”,現在需要取出裡面出現次數最多的字元 第一種方法-裝飾器 得到的結果是: 第二種方法,使用python的collections.Counter 得到的結果 ...
  • 1.設置功能變數名稱後重啟 apache停止了 檢查步驟1.php路徑不要有中文,phpstudy重新安裝在無中文路徑 2.檢查80埠是否被占用,如果被占用可以停止該程式或者修改apache/nginx 埠3.phpstudy ->其他選項->打開配置文件->vhosts 刪除第一行 Listen 80 ...
  • 無法使用Django新建項目:'django-admin.py’不是內部或外部命令找到site-packages/django/bin(如 D:\Program Files\Anaconda3\Lib\site-packages\django\bin),把這個路徑加入系統環境變數中。 error: ...
  • 本身打算把二十三種設計模式,總結一下。總結了幾個設計模式後發現已經有博主總結的非常詳細,內容豐富,我看了後也是受益良多。大家可以參考他的博客,地址如下: https://www.cnblogs.com/abcdwxc/archive/2007/10/30/942834.html 如果看了有幫助,就為 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...