当前位置:   article > 正文

netcore 生成验证码

netcore 生成验证码

安装依赖

Install-Package Lazy.Captcha.Core

注册服务

builder.Services.AddCaptcha();

自定义注册服务

  1. // 注册服务的时候增加配置
  2. services.AddCaptcha(Configuration, option =>
  3. {
  4. option.CaptchaType = CaptchaType.WORD; // 验证码类型
  5. option.CodeLength = 6; // 验证码长度, 要放在CaptchaType设置后. 当类型为算术表达式时,长度代表操作的个数
  6. option.ExpirySeconds = 30; // 验证码过期时间
  7. option.IgnoreCase = true; // 比较时是否忽略大小写
  8. option.StoreageKeyPrefix = ""; // 存储键前缀
  9. option.ImageOption.Animation = true; // 是否启用动画
  10. option.ImageOption.FrameDelay = 30; // 每帧延迟,Animation=true时有效, 默认30
  11. option.ImageOption.Width = 150; // 验证码宽度
  12. option.ImageOption.Height = 50; // 验证码高度
  13. option.ImageOption.BackgroundColor = SkiaSharp.SKColors.White; // 验证码背景色
  14. option.ImageOption.BubbleCount = 2; // 气泡数量
  15. option.ImageOption.BubbleMinRadius = 5; // 气泡最小半径
  16. option.ImageOption.BubbleMaxRadius = 15; // 气泡最大半径
  17. option.ImageOption.BubbleThickness = 1; // 气泡边沿厚度
  18. option.ImageOption.InterferenceLineCount = 2; // 干扰线数量
  19. option.ImageOption.FontSize = 36; // 字体大小
  20. option.ImageOption.FontFamily = DefaultFontFamilys.Instance.Actionj; // 字体
  21. /*
  22. * 中文使用kaiti,其他字符可根据喜好设置(可能部分转字符会出现绘制不出的情况)。
  23. * 当验证码类型为“ARITHMETIC”时,不要使用“Ransom”字体。(运算符和等号绘制不出来)
  24. */
  25. option.ImageOption.TextBold = true;// 粗体,该配置2.0.3新增
  26. });

提供一个生成验证码和校验的接口

  1. /// <summary>
  2. /// 生成验证码
  3. /// </summary>
  4. /// <param name="id"></param>
  5. /// <returns></returns>
  6. [HttpGet]
  7. public IActionResult Captcha(string id)
  8. {
  9. var info = _captcha.Generate(id);
  10. // 有多处验证码且过期时间不一样,可传第二个参数覆盖默认配置。
  11. //var info = _captcha.Generate(id,120);
  12. var stream = new MemoryStream(info.Bytes);
  13. return File(stream, "image/gif");
  14. }
  15. /// <summary>
  16. /// 验证验证码是否输入正确
  17. /// </summary>
  18. [HttpGet]
  19. public bool Validate(string id, string code)
  20. {
  21. return _captcha.Validate(id, code);
  22. }

前端部分

  1. <div class="text-center">
  2. <img id="captchaImage" src="" alt="Captcha Image" />
  3. <input type="text" id="captchaInput" placeholder="Enter the captcha code" />
  4. <button id="validateButton">Validate</button>
  5. <div id="resultMessage"></div>
  6. </div>
  7. <script>
  8. document.addEventListener('DOMContentLoaded', function () {
  9. var guid = generateUUIDv4();
  10. // 加载验证码图片
  11. loadCaptcha();
  12. // 监听验证按钮点击事件
  13. document.getElementById('validateButton').addEventListener('click', validateCaptcha);
  14. // 点击图片刷新验证码
  15. document.getElementById('captchaImage').addEventListener('click', captchaImageClick);
  16. async function captchaImageClick() {
  17. //刷新GUID
  18. guid = generateUUIDv4();
  19. // 重新加载验证码
  20. loadCaptcha();
  21. }
  22. async function loadCaptcha() {
  23. try {
  24. const response = await fetch('/home/Captcha?id=' + guid);
  25. const blob = await response.blob();
  26. const imageUrl = URL.createObjectURL(blob);
  27. document.getElementById('captchaImage').src = imageUrl;
  28. } catch (error) {
  29. console.error('Failed to load captcha:', error);
  30. }
  31. }
  32. async function validateCaptcha() {
  33. const input = document.getElementById('captchaInput').value;
  34. const response = await fetch('/home/Validate?id=' + guid + "&code=" + input);
  35. const data = await response.json();
  36. const messageElement = document.getElementById('resultMessage');
  37. if (data) {
  38. messageElement.textContent = 'Captcha is correct!';
  39. messageElement.style.color = 'green';
  40. } else {
  41. messageElement.textContent = 'Incorrect captcha. Please try again.';
  42. messageElement.style.color = 'red';
  43. //刷新GUID
  44. guid = generateUUIDv4();
  45. // 重新加载验证码
  46. loadCaptcha();
  47. }
  48. }
  49. function generateUUIDv4() {
  50. return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
  51. var r = Math.random() * 16 | 0,
  52. v = c === 'x' ? r : (r & 0x3 | 0x8);
  53. return v.toString(16);
  54. });
  55. }
  56. });
  57. </script>

代码地址:GitHub - maoyuan6/verificationcode: 验证码

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号