.Net Core 實現圖片驗證碼的實現示例_實用技巧

來源:腳本之家  責任編輯:小易  

你可以使用圖章工具繪制出矩形的方格,然后將圖片右鍵托動到圖章當中,在右鍵的屬性中選擇精確裁剪框,然后選中矩形方格,右鍵取消群組,然后點空白的地方,那么整張圖片就被分割成多個小的圖片了。不想使用的地方可以直接點擊選擇后DEL刪除就可以了www.13333515.buzz防采集請勿采集本網。

記錄自己的學習,參考了網上各位大佬的技術,往往在登錄的時候需要使用到驗證碼來進行簡單的一個校驗,這邊使用在.net core上進行生成圖片二維碼

用節點工具編輯好位圖,然后點那個綠色的(我用紅圈圈起來)裁切點陣圖

思路很簡單=》 生成一個隨機數-》保存到服務端Session-》生成隨機碼對應的圖片給前端-》登錄的時候進行校驗(也可以在后端進行隨機碼的token加密,存到Cooick里面在前端進行校驗)

運用節點工具,把圖片上的節點往下移動,有需要的話能添加節點(雙擊)移動到你想要的那個效果

第一步:生成隨機數

可能是順序的問題,應該先把圖片替換玩以后,再執行初始化。或者動態綁定事件。

private static string RndNum(int VcodeNum) { //驗證碼可以顯示的字符集合 string Vchar = "0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f,g,h,i,j,k,l,m,n,p" + ",q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,I,J,K,L,M,N,P,P,Q" + ",R,S,T,U,V,W,X,Y,Z"; string[] VcArray = Vchar.Split(new Char[] { ',' });//拆分成數組 string code = "";//產生的隨機數 int temp = -1;//記錄上次隨機數值,盡量避避免生產幾個一樣的隨機數 Random rand = new Random(); //采用一個簡單的算法以保證生成隨機數的不同 for (int i = 1; i < VcodeNum + 1; i++) { if (temp != -1) { rand = new Random(i * temp * unchecked((int)DateTime.Now.Ticks));//初始化隨機類 } int t = rand.Next(61);//獲取隨機數 if (temp != -1 && temp == t) { return RndNum(VcodeNum);//如果獲取的隨機數重復,則遞歸調用 } temp = t;//把本次產生的隨機數記錄起來 code += VcArray[t];//隨機數的位數加一 } return code; }

(“core導出RGB的圖片和原圖看起來沒多大區別”是你做出來的圖片它的色彩模式本來是RGB的)請看截圖,core中制作的時候可以選cmyk的色彩就行了,那樣做出來以后就沒有區別。哈哈哈,以上我的回答希望能幫

第二步:生成驗證碼圖片

1、改變外界對微軟封閉、自大的印象,繼續推進.NET技術在各個領域的深入,如Unity3D、Xamarin等技術。2、讓.NET系的程序員和非.NET系的程序員都能愉快地使用C#等語言開發應用程序,據我所知

public static MemoryStream Create(out string code, int numbers = 4) { code = RndNum(numbers); //Bitmap img = null; //Graphics g = null; MemoryStream ms = null; Random random = new Random(); //驗證碼顏色集合 Color[] c = { Color.Black, Color.Red, Color.DarkBlue, Color.Green, Color.Orange, Color.Brown, Color.DarkCyan, Color.Purple }; //驗證碼字體集合 string[] fonts = { "Verdana", "Microsoft Sans Serif", "Comic Sans MS", "Arial", "宋體" }; using (var img = new Bitmap((int)code.Length * 18, 32)) { using (var g = Graphics.FromImage(img)) { g.Clear(Color.White);//背景設為白色 //在隨機位置畫背景點 for (int i = 0; i < 100; i++) { int x = random.Next(img.Width); int y = random.Next(img.Height); g.DrawRectangle(new Pen(Color.LightGray, 0), x, y, 1, 1); } //驗證碼繪制在g中 for (int i = 0; i < code.Length; i++) { int cindex = random.Next(7);//隨機顏色索引值 int findex = random.Next(5);//隨機字體索引值 Font f = new Font(fonts[findex], 15, FontStyle.Bold);//字體 Brush b = new SolidBrush(c[cindex]);//顏色 int ii = 4; if ((i + 1) % 2 == 0)//控制驗證碼不在同一高度 { ii = 2; } g.DrawString(code.Substring(i, 1), f, b, 3 + (i * 12), ii);//繪制一個驗證字符 } ms = new MemoryStream();//生成內存流對象 img.Save(ms, ImageFormat.Jpeg);//將此圖像以Png圖像文件的格式保存到流中 } } return ms; }

第三步:控制器調用方法生成隨機數圖片之后,進行隨機數的保存

HttpContext.Session.SetString("LoginValidateCode", code);

備注:在使用Session的時候要進行Session服務的注冊

在ConfigureServices中services.AddSession();

在Configure中app.UseSession();

最后在前端進行驗證碼圖片的綁定

<img style="justify-content:center" id="code" src="/Users/Login/GetVerifyCode" />

點擊圖片進行驗證碼刷新

function GetCode() { $.ajax({ type: "GET", url: "/Users/Login/GetVerifyCode", data: {}, dataType: "json", success: function (data) { }, complete: function () { $("#code").attr('src', '/Users/Login/GetVerifyCode') } }); }

SkiaSharp

這個百度上的搜索結果沒有一個是給了可用代碼的。ε=(´ο`*)))唉 而且大部分都是一個人放出來的代碼 好吧開始自己整。先上代碼

public IActionResult Code() { #region 反射SK支持的全部顏色 //List<SKColor> colors = new List<SKColor>(); //var skcolors = new SKColors(); //var type = skcolors.GetType(); //foreach (FieldInfo field in type.GetFields()) //{ // colors.Add( (SKColor)field.GetValue(skcolors)); //} #endregion //int maxcolorindex = colors.Count-1; string text = "1A3V"; var zu = text.ToList(); SKBitmap bmp = new SKBitmap(80, 30); using (SKCanvas canvas = new SKCanvas(bmp)) { //背景色 canvas.DrawColor(SKColors.White); using (SKPaint sKPaint = new SKPaint()) { sKPaint.TextSize = 16;//字體大小 sKPaint.IsAntialias = true;//開啟抗鋸齒 sKPaint.Typeface = SKTypeface.FromFamilyName("微軟雅黑", SKTypefaceStyle.Bold);//字體 SKRect size = new SKRect(); sKPaint.MeasureText(zu[0].ToString(), ref size);//計算文字寬度以及高度 float temp = (bmp.Width/4 - size.Size.Width)/2; float temp1 = bmp.Height - (bmp.Height - size.Size.Height) / 2; Random random = new Random(); for (int i = 0; i < 4; i++) { sKPaint.Color = new SKColor((byte)random.Next(0,255), (byte)random.Next(0, 255), (byte)random.Next(0, 255)); canvas.DrawText(zu[i].ToString(), temp + 20*i, temp1, sKPaint);//畫文字 } //干擾線 for (int i = 0; i < 5; i++) { sKPaint.Color = new SKColor((byte)random.Next(0, 255), (byte)random.Next(0, 255), (byte)random.Next(0, 255)); canvas.DrawLine(random.Next(0, 40), random.Next(1, 29), random.Next(41, 80), random.Next(1, 29), sKPaint); } } //頁面展示圖片 using (SKImage img = SKImage.FromBitmap(bmp)) { using (SKData p = img.Encode()) { return File(p.ToArray(), "image/Png"); } } } }

到此這篇關于.Net Core 實現圖片驗證碼的實現示例的文章就介紹到這了,更多相關.Net Core 圖片驗證碼內容請搜索真格學網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持真格學網!

出處:https://www.cnblogs.com/net-open/

RESTSHARP獲取圖片資源讀取到FILSTREAM,System.File寫入本地PATH內容來自www.13333515.buzz請勿采集。


  • 本文相關:
  • .net core 2.0如何生成圖片驗證碼完整實例
  • jwt + asp.net mvc時間戳防止重放攻擊詳解
  • asp.net core 3.0 grpc攔截器的使用
  • linq to xml的編程基礎
  • asp.net html文件上傳標簽
  • asp.net母版頁如何使用
  • win8/8.1系統安裝.net framework 3.5出現0x800f0906代碼錯誤的解
  • identityserver4實現.net core api接口權限認證(快速入門)
  • visual studio 2017安裝失敗的解決方法
  • asp.net中各種類型的json格式化
  • asp.net2.0數據庫入門之sql server
  • 我使用 .net core webapi 怎么獲取圖片并存到本地磁盤去
  • 如何在core1draw里把完整的圖片分割出來
  • 終于知道什么情況下需要實現.NET Core中的IOptions接口
  • 終于知道什么情況下需要實現.NET Core中的IOptions接口
  • core里面怎樣裁剪圖片
  • 在core中如何裁剪一張圖片
  • jquery.jqzoom-core框架初始化頁面的后,第一張圖片可以實現圖片放大的效果,用js更換了圖片就不行
  • 為什么core導出cmyk的圖片和原圖相差很大
  • 用什么可以開發net core
  • 在core中如何裁剪一張圖片
  • 網站首頁網頁制作腳本下載服務器操作系統網站運營平面設計媒體動畫電腦基礎硬件教程網絡安全基礎應用實用技巧自學過程首頁asp.net.net core 2.0如何生成圖片驗證碼完整實例jwt + asp.net mvc時間戳防止重放攻擊詳解asp.net core 3.0 grpc攔截器的使用linq to xml的編程基礎asp.net html文件上傳標簽asp.net母版頁如何使用win8/8.1系統安裝.net framework 3.5出現0x800f0906代碼錯誤的解identityserver4實現.net core api接口權限認證(快速入門)visual studio 2017安裝失敗的解決方法asp.net中各種類型的json格式化asp.net2.0數據庫入門之sql serverjava正則表達式 pattern和matche未將對象引用設置到對象的實例 (asp.net(c#)網頁跳轉七種方法小結未能加載文件或程序集“xxx”或它asp.net“服務器應用程序不可用”asp.net中的幾種彈出框提示基本實asp.net gridview 72般絕技asp.net生成excel并導出下載五種asp.net對路徑"xxxxx"asp.net漢字轉拼音和獲取漢字首字.net中as和is之間的區別分析asp.net mvc 項目直接預覽pdf文件.net更新xml中cdata內容的方法實例asp.net替換和恢復html特殊字符asp.net中gridview的文件輸出流方式asp.net各種cookie代碼和解析實例.net獲取當前路徑的方法匯總asp.net實現利用反射,泛型,靜態方法快速asp.net開發sql server轉換成oracle的方法datagridview多維表頭的實現方法
    免責聲明 - 關于我們 - 聯系我們 - 廣告聯系 - 友情鏈接 - 幫助中心 - 頻道導航
    Copyright © 2017 www.13333515.buzz All Rights Reserved
    3排列五开奖结果