首页 > 其他分享 >.NET Core 验证码 - LazyCaptcha

.NET Core 验证码 - LazyCaptcha

时间:2023-07-28 15:55:59浏览次数:37  
标签:Core option 验证码 ImageOption captcha 使用 NET LazyCaptcha id

1.前言

       在开发网站登录,安全验证等方面的时候,我们经常会使用到验证码,以前我们制作验证码的时候,一般都会写大量的代码完成验证码的制作。有没有现成,又好用的验证码工具插件呢?当然是有的,这里就介绍一个开源又好用的验证码工具LazyCaptcha。

2. LazyCaptcha介绍

        LazyCaptcha是仿EasyCaptchaSimpleCaptcha,基于.Net Standard 2.0 的图形验证码模块。使用简单的代码配置,就可以拥有静态图和动态图的展示效果。

3.安装

  Install-Package Lazy.Captcha.Core
  dotnet add package Lazy.Captcha.Core

4.使用

4.1 注册服务

// 默认使用内存存储(AddDistributedMemoryCache)
builder.Services.AddCaptcha(builder.Configuration);

// 如果使用redis分布式缓存
//builder.Services.AddStackExchangeRedisCache(options =>
//{
//    options.Configuration = builder.Configuration.GetConnectionString("RedisCache");
//    options.InstanceName = "captcha:";
//});

4.2 配置

4.2.1  appsettings.json文件配置 (不提供配置时,使用默认配置)

{
      "ConnectionStrings": {
            // 使用Redis缓存时,需要配置此项
            // 使用格式参考 Microsoft.Extensions.Caching.StackExchangeRedis
            "RedisCache": "localhost,password=Aa123456."
       },
      "CaptchaOptions": {
             "CaptchaType": 5, // 验证码类型
             "CodeLength": 4, // 验证码长度, 要放在CaptchaType设置后 当类型为算术表达式时,长度代表操作的个数
             "ExpirySeconds": 60, // 验证码过期秒数
             "IgnoreCase": true, // 比较时是否忽略大小写
             "StoreageKeyPrefix": "", // 存储键前缀
             "ImageOption": {
                   "Animation": false, // 是否启用动画
                   "FontSize": 32, // 字体大小
                   "Width": 100, // 验证码宽度
                   "Height": 40, // 验证码高度
                   "BubbleMinRadius": 5, // 气泡最小半径
                   "BubbleMaxRadius": 10, // 气泡最大半径
                   "BubbleCount": 3, // 气泡数量
                   "BubbleThickness": 1.0, // 气泡边沿厚度
                   "InterferenceLineCount": 4, // 干扰线数量
                   "FontFamily": "kaiti", // 包含actionj,epilog,fresnel,headache,lexo,prefix,progbot,ransom,robot,scandal,kaiti
                   "FrameDelay": 15, // 每帧延迟,Animation=true时有效, 默认30
                   "BackgroundColor": "#ffff00", // 格式: rgb, rgba, rrggbb, or rrggbbaa format to match web syntax, 默认#fff
                   "ForegroundColors": "", // 颜色格式同BackgroundColor,多个颜色逗号分割,随机选取。不填,空值,则使用默认颜色集
                   "Quality": 100, // 图片质量(质量越高图片越大,gif调整无效可能会更大)
                   "TextBold": false // 粗体,该配置2.0.3新增
              }
       }
}

4.2.2 代码配置

// 全部配置
builder.Services.AddCaptcha(builder.Configuration, option =>
{
       option.CaptchaType = CaptchaType.WORD; // 验证码类型
       option.CodeLength = 6; // 验证码长度, 要放在CaptchaType设置后. 当类型为算术表达式时,长度代表操作的个数
       option.ExpirySeconds = 30; // 验证码过期时间
       option.IgnoreCase = true; // 比较时是否忽略大小写
       option.StoreageKeyPrefix = ""; // 存储键前缀

       option.ImageOption.Animation = true; // 是否启用动画
       option.ImageOption.FrameDelay = 30; // 每帧延迟,Animation=true时有效, 默认30

       option.ImageOption.Width = 150; // 验证码宽度
       option.ImageOption.Height = 50; // 验证码高度
       option.ImageOption.BackgroundColor = SixLabors.ImageSharp.Color.White; // 验证码背景色

       option.ImageOption.BubbleCount = 2; // 气泡数量
       option.ImageOption.BubbleMinRadius = 5; // 气泡最小半径
       option.ImageOption.BubbleMaxRadius = 15; // 气泡最大半径
       option.ImageOption.BubbleThickness = 1; // 气泡边沿厚度

       option.ImageOption.InterferenceLineCount = 2; // 干扰线数量

       option.ImageOption.FontSize = 36; // 字体大小
       option.ImageOption.FontFamily = DefaultFontFamilys.Instance.Actionj; // 字体

      /*
       * 中文使用kaiti,其他字符可根据喜好设置(可能部分转字符会出现绘制不出的情况)。
       * 当验证码类型为“ARITHMETIC”时,不要使用“Ransom”字体。(运算符和等号绘制不出来)
      */

      option.ImageOption.TextBold = true;// 粗体,该配置2.0.3新增
});

4.2 Controller中的使用

[Route("captcha")]
[ApiController]
public class CaptchaController : Controller
{
        private readonly ICaptcha _captcha;

        public CaptchaController(ICaptcha captcha)
        {
             _captcha = captcha;
        }

       [HttpGet]
       public IActionResult Captcha(string id)
       {
             var info = _captcha.Generate(id);
            // 有多处验证码且过期时间不一样,可传第二个参数覆盖默认配置。
            //var info = _captcha.Generate(id,120);
            var stream = new MemoryStream(info.Bytes);
            return File(stream, "image/gif");
        }

       /// <summary>
       /// 演示时使用HttpGet传参方便,这里仅做返回处理
       /// </summary>
      [HttpGet("validate")]
      public bool Validate(string id, string code)
     {
           return _captcha.Validate(id, code);
      }

      /// <summary>
      /// 多次校验(https://gitee.com/pojianbing/lazy-captcha/issues/I4XHGM)
      /// 演示时使用HttpGet传参方便,这里仅做返回处理
      /// </summary>
      [HttpGet("validate2")]
      public bool Validate2(string id, string code)
      {
           return _captcha.Validate(id, code, false);
      }
}

5.效果展示

 6.总结

          怎么样,是不是使用起来很简单,还更有多高级功能的使用,请查看官方文档,那么现在你会在项目中使用吗?

标签:Core,option,验证码,ImageOption,captcha,使用,NET,LazyCaptcha,id
From: https://www.cnblogs.com/YDSLM/p/17587828.html

相关文章

  • C# 扫描并读取图片中的文字(.NET Core)
    本文介绍如何通过C#程序来扫描并读取图片中的文字,这里以创建一个.NetCore程序为例。下面是具体步骤,供参考。程序测试环境:VisualStudio版本要求不低于2017图片扫描工具:Spire.OCRfor.NET图片格式:png(这里的图片格式支持JPG、PNG、GIF、BMP、TIFF等格式)扫描的图片文字:中文(......
  • Spire.OCR for .NET
    概述Spire.OCRfor.NET 是一款专业的OCR(图文识别)组件,用以读取JPG、PNG、GIF、BMP和TIFF等图片格式中的文本。利用该组件,开发人员可以用C#和VB.NET创建的.NET应用程序来实现OCR功能。Spire.OCRfor.NET的用法简易,仅需一小串C#或VB.NET的代码,便可轻松读......
  • 【HMS Core】统一扫描连续扫码、闪光灯关闭问题
    ​ 【问题描述1】使用DefaultViewMode进行扫码,如何实现连续扫码 【解决方案】在默认扫码模式DefaultView中,功能是集成在SDK内部的,无法设置连续扫码模式等信息。可以使用CustomizedViewMode这种模式,它提供了相关的api可以设置是否连续扫码:通过setContinuouslyScan方法......
  • 云原生|kubernetes|安全漏扫神器trivy的部署和使用
    前言:云原生领域内的安全漏扫工具有clair和trivy是比较常用的,而安全漏扫工具是可以和harbor这样的私有仓库集成的,自harbor-1.21版以后都是默认使用trivy这个漏扫工具的,而在此之前是使用clair的。那么,本文将就什么是trivy,trivy如何正确的部署,如何正确的使用做一个简单的探讨。一,......
  • NETSDK1004:找不到资产文件
    错误信息严重性代码说明项目文件行禁止显示状态错误NETSDK1004找不到资产文件“C:\BaseContract\obj\project.assets.json”。运行NuGet包还原以生成此文件。BaseContractC:\ProgramFiles\dotnet\sdk\7.0.306\Sdks\Microsoft.NET.Sdk\targets\Microsoft.PackageDe......
  • .net通用RSA加密工具类
    目前最流行的加密算法莫过于RSA了,以下是我们.net/.netcoreC#生成环境用的RSA加密工具类,在此分享给大家。usingSystem;usingSystem.IO;usingSystem.Security.Cryptography;usingSystem.Text;namespaceCommon{///<summary>///RSA加密工具类///</su......
  • .Net6实现定时任务
    首先创建一个类Background实现代码:usingMicrosoft.Extensions.Hosting;usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Text;usingSystem.Threading.Tasks;namespaceSmartMedicalCare.Web{publicclassBackground:IHostedService,......
  • rdma-core之rdma_client.c
    库函数、全局变量#include<stdio.h>#include<stdlib.h>#include<string.h>#include<netdb.h>#include<errno.h>#include<getopt.h>#include<rdma/rdma_cma.h>#include<rdma/rdma_verbs.h>staticconstchar*server......
  • 论文解读|PF-Net:用于 3D 点云补全的点分形网络
    原创|文BFT机器人01 背景从激光雷达等设备中获取的点云往往有所缺失(反光、遮挡等),这给点云的后续处理带来了一定的困难,也凸显出点云补全作为点云预处理方法的重要性。点云补全(PointCloudCompletion)用于修补有所缺失的点云(PointCloud),从缺失点云出发估计完整点云,从而获得更高质......
  • apache net FTPClient 通过 Http 代理访问 FTP服务器
    前言因为特殊原因,需要在服务器上安装一个代理程序,通过代理程序才能访问到安全域内的一台指定IP服务器。该服务器上安装了FTP服务,需要用程序读写FTP上的文件。之前在不使用代理程序的服务器上测试FTP连接,没有任何问题,换到这台服务器上有问题,所以记录一下处理过程。文章目录前言问......