[開源]快速構建驗證碼

来源:https://www.cnblogs.com/MeetYan/archive/2019/04/04/10656129.html
-Advertisement-
Play Games

使用說明 1. 支持WebForm以及Asp.Net Mvc構建驗證碼 2. 項目源碼: " MasterChief.DotNet.Infrastructure.VerifyCode " 3. Nuget:Install Package MasterChief.DotNet.Infrastructu ...


使用說明

  1. 支持WebForm以及Asp.Net Mvc構建驗證碼

  2. 項目源碼:MasterChief.DotNet.Infrastructure.VerifyCode

  3. Nuget:Install-Package MasterChief.DotNet.Infrastructure.VerifyCode

  4. 歡迎Star,歡迎PR;

如何使用

  1. 自定義驗證碼樣式,只需要實現ValidateCodeType抽象類即可

    /// <summary>
     ///     圖片驗證碼抽象類
     /// </summary>
     public abstract class ValidateCodeType
     {
         #region Methods
    
         /// <summary>
         ///     創建驗證碼抽象方法
         /// </summary>
         /// <param name="validataCode">驗證code</param>
         /// <returns>Byte數組</returns>
         public abstract byte[] CreateImage(out string validataCode);
    
         #endregion Methods
    
         #region Constructors
    
         #endregion Constructors
    
         #region Properties
    
         /// <summary>
         ///     驗證碼類型名稱
         /// </summary>
         public abstract string Name { get; }
    
         /// <summary>
         ///     驗證碼Tooltip
         /// </summary>
         public virtual string Tip => "請輸入圖片中的字元";
    
         /// <summary>
         ///     類型名稱
         /// </summary>
         public string Type => GetType().Name;
    
         #endregion Properties
     }
  2. 在WebForm使用說明

    1. 新建一般處理程式

      /// <summary>
      ///     WebFormVerifyCodeHandler 的摘要說明
      /// </summary>
      public class WebFormVerifyCodeHandler : VerifyCodeHandler, IHttpHandler, IRequiresSessionState
      {
          public void ProcessRequest(HttpContext context)
          {
              var validateType = context.Request.Params["style"];
              var buffer = CreateValidateCode(validateType);
              context.Response.ClearContent();
              context.Response.ContentType = MimeTypes.ImageGif;
              context.Response.BinaryWrite(buffer);
          }
      
          public bool IsReusable => false;
      
          public override void OnValidateCodeCreated(HttpContext context, string validateCode)
          {
              context.Session["validateCode"] = validateCode;
          }
      
          public override byte[] CreateValidateCode(string style)
          {
              style = style?.Trim();
              ValidateCodeType createCode;
              switch (style)
              {
                  case "type1":
                      createCode = new ValidateCode_Style1();
                      break;
      
                  default:
                      createCode = new ValidateCode_Style1();
                      break;
              }
      
              var buffer = createCode.CreateImage(out var validateCode);
              OnValidateCodeCreated(HttpContext.Current, validateCode);
              return buffer;
          }
      }
    2. 前端頁面調用

      <body>
          <form runat="server">
          <div class="row">
              <div class="col-md-8">
                  <section id="loginForm">
                      <div class="form-horizontal">
                          <h4>Use a local account to log in.</h4>
                          <hr />
                          <asp:PlaceHolder runat="server" ID="ErrorMessage" Visible="false">
                              <p class="text-danger">
                                  <asp:Literal runat="server" ID="FailureText" />
                              </p>
                          </asp:PlaceHolder>
                          <div class="form-group">
                              <asp:Label runat="server" AssociatedControlID="Email" CssClass="col-md-2 control-label">Email</asp:Label>
                              <div class="col-md-10">
                                  <asp:TextBox runat="server" ID="Email" CssClass="form-control" TextMode="Email" />
                                  <asp:RequiredFieldValidator runat="server" ControlToValidate="Email"
                                      CssClass="text-danger" ErrorMessage="The email field is required." />
                              </div>
                          </div>
                          <div class="form-group">
                              <asp:Label runat="server" AssociatedControlID="Password" CssClass="col-md-2 control-label">Password</asp:Label>
                              <div class="col-md-10">
                                  <asp:TextBox runat="server" ID="Password" TextMode="Password" CssClass="form-control" />
                                  <asp:RequiredFieldValidator runat="server" ControlToValidate="Password" CssClass="text-danger" ErrorMessage="The password field is required." />
                              </div>
                          </div>
                          <div class="form-group">
                              <%--  <asp:Image ID="Image1" runat="server" CssClass="col-md-2 control-label" ImageUrl="BackHandler/WebFormVerifyCodeHandler.ashx" />--%>
                              <img alt="看不清,換一張" class="col-md-2 control-label" src="BackHandler/WebFormVerifyCodeHandler.ashx" onclick="this.src = 'BackHandler/WebFormVerifyCodeHandler.ashx?style=type1&ver=' + Math.random()" />
                              <div class="col-md-10">
                                  <asp:TextBox runat="server" ID="VerifyCode" CssClass="form-control" />
                                  <asp:RequiredFieldValidator runat="server" ControlToValidate="VerifyCode" CssClass="text-danger" ErrorMessage="The VerifyCode field is required." />
                              </div>
                          </div>
                          <div class="form-group">
                              <div class="col-md-offset-2 col-md-10">
                                  <div class="checkbox">
                                      <asp:CheckBox runat="server" ID="RememberMe" />
                                      <asp:Label runat="server" AssociatedControlID="RememberMe">Remember me?</asp:Label>
                                  </div>
                              </div>
                          </div>
                          <div class="form-group">
                              <div class="col-md-offset-2 col-md-10">
                                  <asp:Button runat="server" Text="Log in" CssClass="btn btn-default" OnClick="Login_Click" />
                              </div>
                          </div>
                      </div>
                      <p>
                          <asp:HyperLink runat="server" ID="RegisterHyperLink" ViewStateMode="Disabled">Register as a new user</asp:HyperLink>
                      </p>
                      <p>
                          <%-- Enable this once you have account confirmation enabled for password reset functionality --%>
                          <asp:HyperLink runat="server" ID="ForgotPasswordHyperLink" ViewStateMode="Disabled">Forgot your password?</asp:HyperLink>
                      </p>
                  </section>
              </div>
      
              <div class="col-md-4">
              </div>
          </div>
          </form>
      </body>
    3. 後端頁面使用

      protected void Login_Click(object sender, EventArgs e)
      {
          if (IsValid)
          {
              var verifyCode = VerifyCode.Text.Trim();
              if (string.Compare(Session["validateCode"].ToString(), verifyCode,
                      StringComparison.OrdinalIgnoreCase) != 0)
              {
                  FailureText.Text = "驗證碼驗證不通過.";
                  ErrorMessage.Visible = true;
              }
              else
              {
                  Response.Redirect("Default.aspx");
              }
          }
      }
    4. 運行效果

  3. 在Asp.Net Mvc使用說明

    1. 新建MvcVerifyCodeHandler,並實現抽象類VerifyCodeHandler

      /// <summary>
        ///     處理生成Mvc 程式驗證碼
        /// </summary>
        public sealed class MvcVerifyCodeHandler : VerifyCodeHandler
        {
            public override void OnValidateCodeCreated(HttpContext context, string validateCode)
            {
                context.Session["validateCode"] = validateCode;
            }
      
            public override byte[] CreateValidateCode(string style)
            {
                ValidateCodeType createCode;
                switch (style)
                {
                    case "type1":
                        createCode = new ValidateCode_Style1();
                        break;
                    default:
                        createCode = new ValidateCode_Style1();
                        break;
                }
      
                var buffer = createCode.CreateImage(out var validateCode);
                OnValidateCodeCreated(HttpContext.Current, validateCode);
                return buffer;
            }
        }
    2. 在Controller處理驗證碼生成

      /// <summary>
      ///     生成驗證碼
      /// </summary>
      /// <param name="style">驗證碼樣式</param>
      /// <returns>ActionResult</returns>
      [AllowAnonymous]
      public ActionResult CreateVerifyCode(string style)
      {
          VerifyCodeHandler verifyCodeHandler = new MvcVerifyCodeHandler();
          var buffer = verifyCodeHandler.CreateValidateCode(style);
          return File(buffer, MimeTypes.ImageGif);
      }
    3. 前端頁面調用

      @model MasterChief.Infrastructure.MvcSample.Models.LoginViewModel
      @{
          ViewBag.Title = "Login";
      }
      
      <h2>@ViewBag.Title.</h2>
      <div class="row">
          <div class=" col-md-8">
      
              <section id="loginForm">
                  @using (Html.BeginForm("Login", "Account", new { ViewBag.ReturnUrl }, FormMethod.Post, new { @class = "form-horizontal", role = "form" }))
                  {
                      @Html.AntiForgeryToken()
                      <h4>Use a local account to log in.</h4>
                      <hr />
                      @Html.ValidationSummary(true, "", new { @class = "text-danger" })
                      <div class="form-group">
                          @Html.LabelFor(m => m.Email, new { @class = "col-md-2 control-label" })
                          <div class="col-md-10">
                              @Html.TextBoxFor(m => m.Email, new { @class = "form-control" })
                              @Html.ValidationMessageFor(m => m.Email, "", new { @class = "text-danger" })
                          </div>
                      </div>
                      <div class="form-group">
                          @Html.LabelFor(m => m.Password, new { @class = "col-md-2 control-label" })
                          <div class="col-md-10">
                              @Html.PasswordFor(m => m.Password, new { @class = "form-control" })
                              @Html.ValidationMessageFor(m => m.Password, "", new { @class = "text-danger" })
                          </div>
                      </div>
                      <div class="form-group">
                          <img id="valiCode" style="cursor: pointer;" class="col-md-2 control-label" src="~/Account/CreateVerifyCode" alt="驗證碼" />
                          <div class="col-md-10">
                              @Html.TextBoxFor(m => m.VerifyCode, new { @class = "form-control" })
                              @Html.ValidationMessageFor(m => m.VerifyCode, "", new { @class = "text-danger" })
                          </div>
                      </div>
                      <div class="form-group">
                          <div class="col-md-offset-2 col-md-10">
                              <div class="checkbox">
                                  @Html.CheckBoxFor(m => m.RememberMe)
                                  @Html.LabelFor(m => m.RememberMe)
                              </div>
                          </div>
                      </div>
                      <div class="form-group">
                          <div class="col-md-offset-2 col-md-10">
                              <input type="submit" value="Log in" class="btn btn-default" />
                          </div>
                      </div>
                  }
              </section>
          </div>
          <div class="col-md-4">
              @*<section id="socialLoginForm">
                      @Html.Partial("_ExternalLoginsListPartial", new ExternalLoginListViewModel {ReturnUrl = ViewBag.ReturnUrl})
                  </section>*@
          </div>
      </div>
      
      @section Scripts{
          <script type="text/javascript">
              $(function () {
                  $("#valiCode").bind("click", function () {
                      this.src = "CreateVerifyCode?style=type1&time=" + (new Date()).getTime();
                  });
              });
          </script>
      }
    4. 後端代碼使用

      [HttpPost]
      [AllowAnonymous]
      [ValidateAntiForgeryToken]
      public ActionResult Login(LoginViewModel model, string returnUrl)
      {
          if (!ModelState.IsValid) return View(model);
          if (string.Compare(Session["validateCode"].ToString(), model.VerifyCode,
                  StringComparison.OrdinalIgnoreCase) != 0)
              ModelState.AddModelError("VerifyCode", "驗證碼驗證不通過.");
          else
              return RedirectToAction("Index", "Home");
      
          return View();
      }
    5. 運行效果


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

-Advertisement-
Play Games
更多相關文章
  • 文章大綱 一、JSON介紹二、常見框架介紹與實戰三、Studio中GsonFormat插件使用四、項目源碼下載(含參考資料)五、參考文檔 一、JSON介紹 1. 簡介 JSON 的全稱是 JavaScript Object Notation,是一種輕量級的數據交換格 式。 2. 特點 (1)JSON ...
  • 本文將主要講述 的內部結構和實現邏輯,在看本文之前最好先瞭解一下 隊列鎖, 就是根據 隊列鎖的變種實現的,因為本身 比較複雜不容易看清楚他本身的實現邏輯,所以查看 隊列鎖的實現,可以幫助我們理清楚他內部的關係;關於隊列鎖的內容可以參考 , "CLH、MCS 隊列鎖簡介" ; 一、AQS 結構概述 在 ...
  • 上一篇小樂帶大家學過 Java8新特性-Lambda表達式,那什麼時候可以使用Lambda?通常Lambda表達式是用在函數式介面上使用的。從Java8開始引入了函數式介面,其說明比較簡單:函數式介面(Functional Interface)就是一個有且僅有一個抽象方法,但是可以有多個非抽象方法的 ...
  • 同步容器 在 Java 中,同步容器主要包括 2 類: Vector、Stack、HashTableCollections 類中提供的靜態工廠方法創建的類(由 Collections.synchronizedXxxx 等方法) Vector 實現了 List 介面,Vector 實際上就是一個數組, ...
  • 案情背景 目前公司做新項目,基本所有新項目都是用.net core來做,舊項目一半還是基於 .net framework下麵,一半已經遷移到了core平臺。在做新項目的時候,有個功能需要對接到舊項目那邊的介面,功能也不複雜,就是對接介面的參數需要通過簽名,然後進行MD5加密傳輸過去,舊項目那邊也有相 ...
  • 參考資料 [1] .netCore 源碼 https://github.com/dotnet/corefx [2] 《Unity 3D腳本編程 使用C 語言開發跨平臺游戲》陳嘉棟著 [3] 《數據結構 第四版》 葉核亞編著 [4] @InCerry【淺析C Dictionary實現原理】https: ...
  • 今天遇到過一個朋友的網站一開始放置在百度雲伺服器上運行,但後面決定不再使用百度雲,新購了一臺阿裡雲伺服器,準備將網站應用從百度雲伺服器上遷移到阿裡雲伺服器上,詳細查閱了相關資料後發現,從百度雲遷移到阿裡雲,功能變數名稱備案信息需要在阿裡雲上進行接入備案的操作。 阿裡雲的接入備案指的是:主體和功能變數名稱均已通過其他 ...
  • 授權伺服器設置 添加測試用戶,也可以從資料庫查 添加api資源 ,api的key要和註冊的client的api要匹配 授權碼模式和mvc模式的時候 這兩個模式先不管 //請求確認 可以自定義Claim .AddDeveloperSigningCredential() 生成token 需要的密鑰和公鑰 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...