您现在的位置是:网站首页> 编程资料编程资料
使用.Net Core实现的一个图形验证码功能_实用技巧_
2023-05-24
340人已围观
简介 使用.Net Core实现的一个图形验证码功能_实用技巧_
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
到此这篇关于使用.Net Core实现的一个图形验证码的文章就介绍到这了,更多相关.Net Core图形验证码内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- .NET 与树莓派WS28XX 灯带的颜色渐变动画效果的实现_实用技巧_
- .Net Core微服务网关Ocelot超时、熔断、限流_自学过程_
- .NET Core支持Cookie和JWT混合认证、授权的方法_实用技巧_
- .Net Core微服务网关Ocelot集成Consul_自学过程_
- .Net Core微服务网关Ocelot基础介绍及集成_自学过程_
- .NET微服务架构CI/CD自动构建Jenkins+Gitee_实用技巧_
- Asp.Net Core 使用Monaco Editor 实现代码编辑器功能_实用技巧_
- .NET微服务架构CI/CD自动打包镜像_实用技巧_
- .NET 6开发TodoList应用之实现数据塑形_实用技巧_
- .NET 6开发TodoList应用之实现查询排序_实用技巧_
