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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...