怎么在ASP.NET Core中使用SkiaSharp實現一個驗證碼功能?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
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"); }
看完上述內容,你們掌握怎么在ASP.NET Core中使用SkiaSharp實現一個驗證碼功能的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注創新互聯行業資訊頻道,感謝各位的閱讀!
文章名稱:怎么在ASP.NETCore中使用SkiaSharp實現一個驗證碼功能-創新互聯
網站鏈接:http://vcdvsql.cn/article26/ceohcg.html
成都網站建設公司_創新互聯,為您提供App設計、全網營銷推廣、網站制作、建站公司、網站策劃、響應式網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯