SimpleCaptcha是一个使用简单,基于.Net Standard 2.0的图形验证码模块。它的灵感来源于Edi.Wang的这篇文章https://edi.wang/post/2018/10/13/generate-captcha-code-aspnet-core,我将其中生成验证码的代码抽取出来进行封装得到了这个模块。下面介绍一下使用方式。
在Nuget中搜索安装SimpleCaptcha
SimpleCaptcha依赖Microsoft.Extensions.Caching.Abstractions模块用来存储验证码,所以你需要在项目中根据自己的需要安装相应的实现包,例如这里我使用Microsoft.Extensions.Caching.Memory
修改Startup.cs文件注入相应的服务:
services.AddMemoryCache()
.AddSimpleCaptcha(builder =>
{
builder.UseMemoryStore();
});
在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 });
}
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 www.lanboylgw.com=>
{www.xingyunylpt.com
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 www.jintianxuesha.com CaptchaImageGenerator : ICaptchaImageGenerator
{
public byte[www.tianshun178.cn] Generate(int width, int height, string captchaCode)
{
www.tengyao3zc.cn throw new NotImplementedException();
}
}
services.AddSimpleCaptcha(builder www.yacuangyl.com=>
{
builder.AddConfiguration(options www.keLezaix.com=>
{
options.ImageGenerator = new CaptchaImageGenerator(www.lcx528.cn );