ASP.NET Core使用SkiaSharp实现验证码教程
程序员文章站
2022-04-08 10:55:19
前言
本文并没有实现一个完成的验证码样例,只是提供了在当前.NET Core 2.0下使用Drawing API的另一种思路,并以简单Demo的形式展示出来。
Skia
Sk...
前言
本文并没有实现一个完成的验证码样例,只是提供了在当前.NET Core 2.0下使用Drawing API的另一种思路,并以简单Demo的形式展示出来。
Skia
Skia是一个开源的二维图形库,提供各种常用的API,并可在多种软硬件平台上运行。谷歌Chrome浏览器、Chrome OS、安卓、火狐浏览器、火狐操作系统以及其它许多产品都使用它作为图形引擎。
Skia由谷歌出资管理,任何人都可基于BSD免费软件许可证使用Skia。Skia开发团队致力于开发其核心部分, 并广泛采纳各方对于Skia的开源贡献。
SkiaSharp
SkiaSharp是由Mono发起,基于谷歌的Skia图形库,实现的一个跨平台的2D图形.NET API绑定。提供一个全面的2D API,可用于跨移动、服务器和桌面模式的图形渲染和图像处理。
skiasharp提供PCL和平台特定的绑定:
.NET Core / .NET Standard 1.3
Xamarin.Android
Xamarin.iOS
Xamarin.tvOS
Xamarin.Mac
Windows Classic Desktop (Windows.Forms / WPF)
Windows UWP (Desktop / Mobile / Xbox / HoloLens)
使用SkiaSharp
dotnet add package SkiaSharp --version 1.59.3
ASP.NET验证码
前使用SkiaSharp实现文本绘图功能,代码如下:
internal static byte[] GetCaptcha(string captchaText) { byte[] imageBytes = null; int image2d_x = 0; int image2d_y = 0; SKRect size; int compensateDeepCharacters = 0; using (SKPaint drawStyle = CreatePaint()) { compensateDeepCharacters = (int)drawStyle.TextSize / 5; if (System.StringComparer.Ordinal.Equals(captchaText, captchaText.ToUpperInvariant())) compensateDeepCharacters = 0; size = SkiaHelpers.MeasureText(captchaText, drawStyle); image2d_x = (int)size.Width + 10; image2d_y = (int)size.Height + 10 + compensateDeepCharacters; } using (SKBitmap image2d = new SKBitmap(image2d_x, image2d_y, SKColorType.Bgra8888, SKAlphaType.Premul)) { using (SKCanvas canvas = new SKCanvas(image2d)) { canvas.DrawColor(SKColors.Black); // Clear using (SKPaint drawStyle = CreatePaint()) { canvas.DrawText(captchaText, 0 + 5, image2d_y - 5 - compensateDeepCharacters, drawStyle); } using (SKImage img = SKImage.FromBitmap(image2d)) { using (SKData p = img.Encode(SKEncodedImageFormat.Png, 100)) { imageBytes = p.ToArray(); } } } } return imageBytes; }
ASP.NET Core输出图像:
[HttpGet("/api/captcha")] public IActionResult Captcha() { var bytes = SkiaCaptcha.Captcha.GetCaptcha("hello world"); return File(bytes, "image/png"); }
推荐阅读
-
.Net Core 下使用ZKWeb.System.Drawing实现验证码功能(图形验证码)
-
ASP.NET Core静态文件使用教程(9)
-
在Asp.Net Core中配置使用MarkDown富文本编辑器实现图片上传和截图上传(开源代码.net core3.0)
-
在ASP.NET Core中使用托管启动(hosting startup)程序集,实现批量注册service
-
ASP.NET Core 3.0 使用AspectCore-Framework实现AOP
-
ASP.NET Core 2.0 使用NLog实现日志记录
-
ASP.NET CORE 使用Consul实现服务治理与健康检查(2)——源码篇
-
在Mac上开发使用yoeman构建Asp.net core项目并且实现分层引用
-
[Asp.Net Core] 为什么选择 Blazor Server Side (一) 快速实现图片验证码
-
asp.net core 实现 face recognition 使用 tensorflowjs(源代码)