当前位置: 首页 > news >正文

项目中的图形验证码是前端还是后端实现?

图形验证码的生成和验证通常由后端负责,而前端主要负责展示和用户交互。以下是具体的分工和实现逻辑:

1.后端职责

后端负责生成图形验证码的图片和对应的验证码字符串,并将其存储在缓存(如 Redis)或会话(Session)中。后端还需要提供接口供前端请求验证码图片,并在用户提交时验证输入的验证码是否正确。

示例代码展示了如何使用 Hutool 工具生成图形验证码:

@GetMapping("/getCode")
public Result<Map<String, String>> getCode() {LineCaptcha lineCaptcha = CaptchaUtil.createLineCaptcha(200, 100);String uuid = IdUtil.simpleUUID();String code = lineCaptcha.getCode();// 将验证码存储到 Redis,设置有效期为1分钟redisTemplate.opsForValue().set(uuid, code, Duration.ofMinutes(1));// 将验证码图片转换为 Base64 格式返回给前端FastByteArrayOutputStream os = new FastByteArrayOutputStream();lineCaptcha.write(os);Map<String, String> result = new HashMap<>();result.put("uuid", uuid);result.put("img", Base64.encode(os.toByteArray()));return Result.ok(result);
}

2.前端职责

前端通过调用后端接口获取验证码图片,并将其展示在页面上。当用户输入验证码后,前端将用户输入的验证码和后端返回的唯一标识(如 UUID)一起提交到后端进行验证。

前端展示验证码的示例:

request.get('/getCode').then(res => {if (res.code === 200) {this.codeUrl = "data:image/gif;base64," + res.data.img;this.loginForm.uuid = res.data.uuid;}
});

3.验证逻辑

用户提交登录信息时,后端会根据 UUID 从缓存中获取验证码,并与用户输入的验证码进行比对。如果验证通过,则继续处理登录逻辑;否则返回错误提示。(一般由后端来做验证,也可以由前端获取验证码进行验证)

示例验证代码:

@PostMapping("/login")
public Result<?> login(@RequestBody LoginDto loginDto) {String uuid = loginDto.getUuid();String code = loginDto.getCode();// 从 Redis 中获取验证码并验证String storedCode = redisTemplate.opsForValue().get(uuid);if (!Objects.equals(storedCode, code)) {return Result.fail("验证码错误,请重新验证");}// 验证成功后清除缓存redisTemplate.delete(uuid);// 继续处理登录逻辑
}

4.前端生成验证码的场景

在某些情况下,图形验证码也可以由前端生成(如使用 HTML5 Canvas)或者(

Hutool工具中的captcha包中的图形验证码来实现。验证码功能位于cn.hutool.captcha包中,核心接口为ICaptcha)。这种方式适用于对安全性要求较低的场景,但由于前端生成的验证码容易被破解,通常不建议用于关键业务。

5.总结

图形验证码的生成和验证主要由后端完成,以确保安全性和数据一致性。前端负责展示验证码图片和收集用户输入。通过这种分工,可以有效防止恶意攻击和自动化脚本操作。

若要由前端实现图形验证码功能:参考文章

http://www.dtcms.com/a/390958.html

相关文章:

  • ✅ 基于Scrapy与朴素贝叶斯的校园舆情监测与预警系统 Django+B/S架构 可视化大屏 机器学习
  • Unity UI 插件 | Easy Popup System
  • AI证件照制作 API 快速生成证件照
  • @RequestParam和 @RequestBody能一起用吗
  • 构建高效的电商爬虫代理池:从架构设计到实战优化
  • 使用cJSON库实现JSON与C结构体的互转
  • Cursor :Python 运行路径设置自定义模块导入报错:No module named ‘xxx’ 的解决方案
  • 数图信息科技亮相唐山社区零售论坛,数字化赋能行业高质量发展
  • LLM大模型 - 实战篇 - Assistant API 原理与实战应用
  • python微博舆情分析系统 情感分析 爬虫 机器学习 新浪微博 数据采集 大数据技术(源码)✅
  • FreeRTOS消息队列剖析讲解(思路+源码)
  • Trillium Engineering-无人机万向节有效负载 - 用于战术 UAS 的 EO 和 EO/IR 无人机相机万向节
  • 【Linux网络】Socket编程预备
  • pyAutoGUI 模块主要功能介绍-(4)消息框功能
  • 自学嵌入式第四十三天:硬件方面-ARM体系架构
  • PDF清晰度提升的幕后英雄:ImprovePdf
  • 《中国垒球规则》快投垒球局面规则·垒球5号位
  • Spring Boot 快速入门:构建企业级微服务架构
  • 【论文阅读】 WebDancer: Towards Autonomous Information Seeking Agency
  • MySQL集群运维
  • 未来浏览器:重新定义信息获取与交互
  • Mybatis-plus插件功能
  • weex分析美联储降息新周期:市场迎来机遇与挑战
  • Micronaut 集成 SPL 实现微服务
  • 类加载的过程以及双亲委派模型
  • 将 RabbitMQ 与 .NET Core Web API 和 Worker Services 结合使用
  • 面试编程题(三)
  • SSD性能优化之4K对齐
  • dolphindb vscode更改连接配置的操作步骤
  • 船用配电盘在线绝缘监测故障定位系统