網站首頁 編程語言 正文
SimpleCaptcha是一個使用簡單,基于.Net Standard 2.0的圖形驗證碼模塊。它的靈感來源于Edi.Wang的這篇文章https://edi.wang/post/2018/10/13/generate-captcha-code-aspnet-core,我將其中生成驗證碼的代碼抽取出來進行封裝得到了這個模塊。下面介紹一下使用方式。
基本使用方式
安裝SimpleCaptcha
在Nuget中搜索安裝SimpleCaptcha
安裝緩存模塊
SimpleCaptcha依賴Microsoft.Extensions.Caching.Abstractions模塊用來存儲驗證碼,所以你需要在項目中根據自己的需要安裝相應的實現包,例如這里我使用Microsoft.Extensions.Caching.Memory
Startup
修改Startup.cs文件注入相應的服務:
services.AddMemoryCache() .AddSimpleCaptcha(builder => { builder.UseMemoryStore(); });
注入ICaptcha接口
在Controller中注入核心接口ICaptcha
private readonly ICaptcha _captcha; public HomeController(ICaptcha captcha) { _captcha = captcha; }
生成驗證碼
使用ICaptcha接口的Generate
方法生成驗證碼
public IActionResult Captcha(string id) { var info = _captcha.Generate(id); var stream = new MemoryStream(info.CaptchaByteData); return File(stream, "image/png"); }
驗證
使用ICaptcha接口的Validate
方法對用戶的提交進行驗證
public IActionResult Validate(string id, string code) { var result = _captcha.Validate(id, code); return Json(new { success = result }); }
完整的例子可以在這里找到:https://github.com/1992w/SimpleCaptcha/tree/master/src/SimpleCaptcha.Demo
配置
SimpleCaptcha預留了一些默認的配置項,你可以根據需要自行修改。
設置驗證碼長度
services.AddSimpleCaptcha(builder => { builder.AddConfiguration(options => { options.CodeLength = 6; }); });
設置圖片大小
services.AddSimpleCaptcha(builder => { builder.AddConfiguration(options => { options.ImageWidth = 100; options.ImageHeight = 36; }); });
設置區分大小寫
默認情況下驗證不區分大小寫
services.AddSimpleCaptcha(builder => { builder.AddConfiguration(options => { options.IgnoreCase = false; }); });
設置驗證碼有效期
驗證碼默認的有效期為5分鐘
services.AddSimpleCaptcha(builder => { builder.AddConfiguration(options => { options.ExpiryTime =TimeSpan.FromMinutes(10); }); });
設置字符集
SimpleCaptcha提供了ICaptchaCodeGenerator
接口用來生成字符,默認的實現是從字符集012346789ABCDEFGHIJKLMNOPQRSTUVWXYZ
中隨機生成,你可以繼承ICaptchaCodeGenerator接口實現自己的需求。
public class MyCaptchaCodeGenerator : ICaptchaCodeGenerator { public string Generate(int length) { throw new NotImplementedException(); } }
配置自己的生成器
services.AddSimpleCaptcha(builder => { builder.AddConfiguration(options => { options.CodeGenerator = new MyCaptchaCodeGenerator(); }); });
設置個性化的圖片
如果默認生成的圖片你覺得不符合你的要求,你可以實現ICaptchaImageGenerator
接口進行修改
public class CaptchaImageGenerator : ICaptchaImageGenerator { public byte[] Generate(int width, int height, string captchaCode) { throw new NotImplementedException(); } }
services.AddSimpleCaptcha(builder => { builder.AddConfiguration(options => { options.ImageGenerator = new CaptchaImageGenerator(); }); });
源代碼
所有源代碼可以在這里獲取:https://github.com/1992w/SimpleCaptcha
原文鏈接:https://www.cnblogs.com/jiangbingyang/p/13238190.html
相關推薦
- 2022-05-04 詳解Python函數式編程之裝飾器_python
- 2022-07-10 DHCP服務配置——CentOS/Windows2003
- 2022-06-11 在Docker容器中部署MSSQL_docker
- 2022-08-13 electron功能實現---添加全局快捷鍵、開機自啟、選擇安裝路徑
- 2022-12-24 Kubernetes?ApiServer三大server權限與數據存儲解析_云和虛擬化
- 2022-11-05 Android?View轉換為Bitmap實現應用內截屏功能_Android
- 2022-09-16 Kubernetes教程之Windows?HostProcess?運行容器化負載_云其它
- 2022-07-22 Math.ceil() 函數使用介紹
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支