一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - ASP.NET教程 - .Net Core 實現(xiàn)圖片驗證碼的實現(xiàn)示例

.Net Core 實現(xiàn)圖片驗證碼的實現(xiàn)示例

2020-06-28 14:39.Net_Mr.Liu ASP.NET教程

這篇文章主要介紹了.Net Core 實現(xiàn)圖片驗證碼的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

記錄自己的學(xué)習(xí),參考了網(wǎng)上各位大佬的技術(shù),往往在登錄的時候需要使用到驗證碼來進(jìn)行簡單的一個校驗,這邊使用在.net core上進(jìn)行生成圖片二維碼

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

第一步:生成隨機(jī)數(shù)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
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[] { ',' });//拆分成數(shù)組 
      string code = "";//產(chǎn)生的隨機(jī)數(shù)
      int temp = -1;//記錄上次隨機(jī)數(shù)值,盡量避避免生產(chǎn)幾個一樣的隨機(jī)數(shù)
 
      Random rand = new Random();
      //采用一個簡單的算法以保證生成隨機(jī)數(shù)的不同
      for (int i = 1; i < VcodeNum + 1; i++)
      {
        if (temp != -1)
        {
          rand = new Random(i * temp * unchecked((int)DateTime.Now.Ticks));//初始化隨機(jī)類
        }
        int t = rand.Next(61);//獲取隨機(jī)數(shù)
        if (temp != -1 && temp == t)
        {
          return RndNum(VcodeNum);//如果獲取的隨機(jī)數(shù)重復(fù),則遞歸調(diào)用
        }
        temp = t;//把本次產(chǎn)生的隨機(jī)數(shù)記錄起來
        code += VcArray[t];//隨機(jī)數(shù)的位數(shù)加一
      }
      return code;
    }

第二步:生成驗證碼圖片

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
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);//背景設(shè)為白色
 
          //在隨機(jī)位置畫背景點
          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);//隨機(jī)顏色索引值
            int findex = random.Next(5);//隨機(jī)字體索引值
            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();//生成內(nèi)存流對象
          img.Save(ms, ImageFormat.Jpeg);//將此圖像以Png圖像文件的格式保存到流中
        }
      }
 
      return ms;
    }

第三步:控制器調(diào)用方法生成隨機(jī)數(shù)圖片之后,進(jìn)行隨機(jī)數(shù)的保存

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

備注:在使用Session的時候要進(jìn)行Session服務(wù)的注冊

在ConfigureServices中services.AddSession();

在Configure中app.UseSession();

最后在前端進(jìn)行驗證碼圖片的綁定

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

點擊圖片進(jìn)行驗證碼刷新

.Net Core 實現(xiàn)圖片驗證碼的實現(xiàn)示例

?
1
2
3
4
5
6
7
8
9
10
11
12
13
function GetCode() {
    $.ajax({
      type: "GET",
      url: "/Users/Login/GetVerifyCode",
      data: {},
      dataType: "json",
      success: function (data) {
      },
      complete: function () {
        $("#code").attr('src', '/Users/Login/GetVerifyCode')
      }
    });
  }

SkiaSharp

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
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");
          }
        }
      }
    }

到此這篇關(guān)于.Net Core 實現(xiàn)圖片驗證碼的實現(xiàn)示例的文章就介紹到這了,更多相關(guān).Net Core 圖片驗證碼內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

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

原文鏈接:https://www.cnblogs.com/net-open/p/12543033.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 秀婷程仪公欲息肉婷在线观看 | acg火影忍者熟密姬纲手h | 国产在线影院 | 手机在线观看精品国产片 | 亚洲精品动漫在线观看 | 国产成人精品免费2021 | 国产情侣视频观看 | 好大用力深一点女公交车 | 国产精品成人 | 日本午夜视频 | 日韩在线视频二区 | ts人妖国产一区 | 欧美日韩中文国产一区 | 99热国产在线观看 | 国产乱码免费卡1卡二卡3卡四 | 欧美日韩综合网在线观看 | 特级淫片欧美高清视频蜜桃 | 校花在公车上被内射好舒 | 四虎影视在线永久免费观看 | 婷婷激情综合五月天 | 99色在线视频 | 日本一区二区视频在线观看 | 美女黄a | 洗濯屋H纯肉动漫在线观看 武侠艳妇屈辱的张开双腿 午夜在线观看免费观看 视频 | 秋霞黄色大片 | 亚洲福利在线观看 | 青青热久免费精品视频精品 | 国产精品第 | 天天做天天玩天天爽天天 | 女同69式互添在线观看免费 | 亚洲欧美精品一区天堂久久 | 校花被扒开尿口折磨憋尿 | 成人丁香乱小说 | 17个农民工婉莹第一部 | 四虎精品免费视频 | 成年男女免费视频网站 | 爱福利视频一区 | 阿 好深 快点 老师受不了 | 肉性天堂| 男同志gays| 精品久久久久久影院免费 |