登錄界面設計之三:界面搭建

来源:https://www.cnblogs.com/punisherCN/archive/2019/01/22/10305829.html
-Advertisement-
Play Games

登錄界面的搭建還是比較簡單的,雖然有點簡陋,但能用的姑且當做好的吧,如下圖: 這裡使用的是DevExpress控制項,其中值得一看的就是使用LayoutControl控制項來進行TextEdit控制項的佈局。對於一般幾個TextEdit併排的佈局而言,使用這個控制項的效果還是不錯的。 既然涉及到了系統的登錄 ...


  登錄界面的搭建還是比較簡單的,雖然有點簡陋,但能用的姑且當做好的吧,如下圖:

這裡使用的是DevExpress控制項,其中值得一看的就是使用LayoutControl控制項來進行TextEdit控制項的佈局。對於一般幾個TextEdit併排的佈局而言,使用這個控制項的效果還是不錯的。


  既然涉及到了系統的登錄,那麼自然少不了資料庫的連接等操作了。這裡,我自己做的時候也很亂,爭取能表述的清楚一些。

首先,如果要訪問資料庫,那沒庫不行哈。那麼,就趕著手頭的東西,趕緊弄個庫出來吧。

資料庫創建與表設計

  具體流程就是:創立一個Access2007格式的資料庫文件,這裡名稱為:BoardWages.accdb。別忘了給它創建個密碼,不過具體過程就略了,如果有和我一樣的小白,沒關係,咱稍微搜一下就OK了。然後再創建一個名為tbUser的表,並建立欄位,如下圖所示:

  其中,ID欄位為自動編號;Name欄位為文本格式,保存用戶名;Password為文本欄位,保存密碼的MD5散列值。為啥是MD5格式?因為這樣別人即使打開了你的資料庫也無法看到真實的密碼!如果還有人問為啥不能反推,那我也就不能解釋了……

MD5函數

  參考代碼:

 1     /// <summary>
 2     ///  MD5操作類
 3     /// </summary>
 4     public class MD5Hashing
 5     {
 6         /// <summary>
 7         ///  MD5加密演算法
 8         /// </summary>
 9         /// <param name="input">要加密的字元串</param>
10         /// <param name="encode">編碼類型</param>
11         /// <returns></returns>
12         public static string MD5Encrypt(string input, Encoding encode)
13         {
14             MD5 md5 = new MD5CryptoServiceProvider();
15             byte[] t = md5.ComputeHash(encode.GetBytes(input));
16             StringBuilder sb = new StringBuilder(32);
17             for (int i = 0; i < t.Length; i++)
18             {
19                 sb.Append(t[i].ToString("x").PadLeft(2, '0'));
20             }
21             return sb.ToString();
22         }
23     }

  好了,說完資料庫,繼續說資料庫訪問的事。最早,自己學習的時候,學了ODBC,還有OLEDB,再之後的ado.net,直接寫SQL代碼,對於很多像我這樣的小白而言,是很容易出錯的,所以,各位大大們,就弄出了很多的ORM組件,解決了小白們的問題。這裡,我使用的是秋大的CYQ.Data,因為這個接觸的多,用慣了,也確實很好用。還是老規矩,先把代碼貼上再慢慢說:

 1             // 使用自定義的方法,利用Validate組件進行驗證
 2             // 但要註意的是,需要把控制項的tag屬性進行設置
 3             if (MyValidator.IsEmpty(txtName,txtPassword) == false)
 4             {
 5                 return;
 6             }
 7 
 8             // 驗證沒問題之後,獲取控制項內的用戶名和密碼
 9             string name = txtName.Text.Trim();          // 用戶名
10             string password = txtPassword.Text.Trim();  // 密碼
11 
12             // 在資料庫中進行查詢
13             using (MAction action = new MAction(tbUser, MyAPPConfig.LocalConn))
14             {
15                 if (!action.Exists("Name = '" + name + "'"))        //  是否存在用戶名?
16                 {
17                     CShowMsg.ShowWarning(string.Format("用戶名'{0}'不存在",name));
18                     return;
19                 }
20                 else
21                 {
22                     // 對密碼進行MD5加密,再進行判斷
23                     string md5Password = MD5Hashing.MD5Encrypt(password, Encoding.UTF8);
24                     string where = string.Format("Name = '{0}' and Password = '{1}'",name,md5Password);
25                     if (!action.Exists(where))
26                     {
27                         CShowMsg.ShowWarning("用戶名或者密碼不正確!");
28                         return;
29                     }
30                     else
31                     {
32                         // 這一句,就可以關閉當前的頁面了。因為在Program中進行了處理。
33                         this.DialogResult = System.Windows.Forms.DialogResult.OK;
34                     }
35                 }
36             }

  註意了,包含在using中的代碼就是使用CYQ.Data的具體代碼了,這裡先查看是否存在用戶名,再查看是否存在用戶名和密碼都存在的記錄。代碼是下午寫的,現在感覺,這裡重覆了,直接進行第二組判斷應該就可以了。其中,把判斷條件添加進去,這裡我使用的是string.Format方法來組成了字元串來當做查詢條件。具體的CYQ.Data怎麼用,我想沒有比秋大的博客更好的地方了,大家可以自行搜索。

  需要更多說明的有三個地方:

1、MyAPPConfig.LocalConn 是自己定義的Access的連接字元串,這裡是:Provider=Microsoft.ACE.OLEDB.12.0;Data Source=.\Data\BoardWages.accdb;Persist Security Info=True;Jet OLEDB:Database Password=boardwages!2019
2、CShowMsg.ShowWarning 是自定義的一個輸出方法,其實就是對於 MessageBox.Show方法的一個封裝而已。
3、MyValidator.IsEmpty也是自定義的一個方法,目的是判斷指定的控制項是否內容為空,如果是,會有相應的提示,例如:

 


這裡涉及到了FluentValidation驗證組件的使用,回頭需要專門的用一章來說明。

 小結:好了,下午大概就做了這些內容,最後就是在資料庫中手動添加一條記錄,然後自己在登錄界面中,使用正確的用戶名和密碼進行登錄,看是否能夠登錄成功以驗證我們數據訪問組件使用的是否正確。寫的比較倉促,有問題的地方,大家多多批評指正。

 


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

-Advertisement-
Play Games
更多相關文章
  • SG函數先不說,給自己總結下三大博弈。和二進位及黃金分割聯繫密切,數學真奇妙,如果不用考試就更好了。 1.Bash Game:n個物品,最少取1個,最多取m個,先取完者勝。 給對手留下(m+1)的倍數肯定獲勝。若n%(m+1)==0,先手必敗。 51nod裸題:1066 2.Nim Game:n堆物 ...
  • CImage類中GetPixelAddress()函數來設置獲取對應的顏色值是發現Alpha無效。 不管 newBuffer[3] = a; 如何設置 newImage始終無法透明。 這裡要註意的是 newImage.Create(width,height,32); 這裡第三個函數一定要設置為32 ...
  • 函數遞歸 函數遞歸:函數的遞歸調用,即在函數調用的過程中,又直接或間接地調用了函數本身 直接調用 間接調用 ...
  • 1 # -*- conding=utf-8 -*- 2 3 import requests 4 from bs4 import BeautifulSoup 5 import io 6 7 url = "https://www.mzitu.com/164871" 8 #Referer = ? 是模擬電 ...
  • 一.概述 本文介紹處理 ASP.NET Core 應用中常見錯誤的一些方法。主要是關於:開發環境異常頁;非開發環境配置自定義異常處理頁;配置狀態代碼頁(沒有正文響應,http狀態400~599的)。 1.1 開發環境異常頁 要將應用配置為顯示有關異常的詳細信息的頁面,請使用開發環境異常頁。要環境設置 ...
  • 由於谷歌翻譯官方API是付費版本,本著免費和開源的精神。分享一下用 Net Core 實現谷歌翻譯API的代碼。 項目引用的Nuget 包: ChakraCore.NET Newtonsoft.Json JavaScriptEngineSwitcher.ChakraCore.Native.win-x ...
  • 一.編寫併發布WebService服務 1.新建空web應用程式 2.右鍵項目解決方案-添加-新建項-選擇web服務 添加完成如下: 3.可以看到實例代碼里有這一行註釋,請取消註釋,因為我們要使用ajax來調用webservice // [System.Web.Script.Services.Scr ...
  • 公司項目最近出現獲取訪問功能變數名稱、埠、IP錯誤現象,通過排查發現, 之前項目一直通過Nginx自定義Headers信息來獲取,但最近運維人員失誤操作造成自定義Header信息丟失,造成項目拿不到對應的數據。思前想後,想找找官方有沒有關於此類問題通用標準化的解決方案。 一、Nginx配置如下: 二、.N ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...