当前位置:首页 > 科技  > 软件

Springboot3.x 中实现滑动拼图验证码的全面指南

来源: 责编: 时间:2024-05-09 09:29:50 121观看
导读这个专题深入浅出地探讨了各类验证码的生成和在Springboot3.x中的实践,从基础的滑动、点选、算术运算验证码到创新的艺术风格、水印、二维码验证码,适合所有Java开发者阅读。在这个专题中,不仅可以学习到技术实践,更能领
这个专题深入浅出地探讨了各类验证码的生成和在Springboot3.x中的实践,从基础的滑动、点选、算术运算验证码到创新的艺术风格、水印、二维码验证码,适合所有Java开发者阅读。在这个专题中,不仅可以学习到技术实践,更能领略到验证码的美学魅力。让我们一起探索验证码的无尽可能性。

滑动拼图验证码作为用户身份验证的一种方式,它的主要作用是进行人机行为区分,防止针对网站或者应用的恶意机器行为。这种验证码尤其适用于防止恶意的批量注册、登录爬虫以及自动化攻击,比如说防止一些验证码识别的机器人。crU28资讯网——每日最新资讯28at.com

基本的滑动拼图验证码通常由一个背景图像和一个缺失的图像片段组成,用户需要通过鼠标操作将缺失的片段准确滑动至应在的位置。在这个过程中,用户的行为数据(包括滑动轨迹,滑动速度,滑动时间等)都可以被用来进行用户和机器的区分,因此滑动拼图验证码又有着非常高的安全性。crU28资讯网——每日最新资讯28at.com

与传统的文本验证码相比,滑动拼图验证码具有更好的用户体验和更高的安全性:文本验证码往往需要用户仔细观察,输入错误率高,给用户带来不便,而且现在有许多OCR技术可以成功识别文本验证码。滑动拼图验证码则只需要用户执行一个自然的,直觉的动作,用户错误率低,同时机器人模拟出人类完全一致的行为几乎是不可能的。crU28资讯网——每日最新资讯28at.com

理解原理:滑动拼图验证码的运行机制

滑动拼图验证码的运行包括了后端服务和前端交互两大部分,我们先来知道整体的流程,再逐一深入。crU28资讯网——每日最新资讯28at.com

  1. 后端生成图像:后端首先生成一张完整的图像和一个带有缺口的复制图像。这个缺口通常是一个特定的形状,如圆形、方形等,或者是一段特定轮廓的形状。这样就形成了一对背景图像和滑块图像,缺口的形状和大小在这两张图像中是完全一致的。
  2. 前端展示与交互:后端将这两张图像发送给前端,前端将背景图像正常展示,而滑块图像则位于一边,等待用户进行拖动。
  3. 用户操作滑块:用户通过鼠标或触屏操作,将滑块图像拖动至背景图像中的缺口部分。在这个操作过程中,前端会记录下用户的行为数据,这些数据包括但不限于滑动开始和结束的时间、滑动轨迹、滑动速度等。
  4. 前端发送验证数据:当用户完成拖动后,或者用户拖动滑块超出一定范围后,前端将滑动的结果以及行为数据发送给后端。这个结果就是滑块在背景图像中的位置,或者说是滑动的距离。
  5. 后端验证:后端根据发送来的滑动结果,以及用户的行为数据,进行验证。如果滑动结果与后端最初设定的缺口位置一致,或者在一定的误差范围内,同时用户的行为数据也符合正常人类的行为,那么后端判定这次验证码验证成功,返回验证成功的结果。

技术实现:在Springboot3.x中如何生成滑动拼图验证码

下面我们将实现一个简单的 Spring Boot 工程来生成滑动拼图验证码。我们的项目中主要包括四个部分,分别为原始图片的获取,将原始图片转换为带缺口的滑动验证码图片,前端的验证码显示和操作以及后端的数据验证。crU28资讯网——每日最新资讯28at.com

后端:生成滑动拼图验证码

我们首先需要一个原始图片,这个图片将会被转换为验证码图片。原始图片可以是任何图片文件,例如originalImage.png,存放在项目的资源文件夹中。crU28资讯网——每日最新资讯28at.com

后端用来生成验证码的核心代码如下:crU28资讯网——每日最新资讯28at.com

@RestControllerpublic class ImageController {    private final ImageService imageService;    public ImageController(ImageService imageService) {        this.imageService = imageService;    }    @GetMapping("/captcha")    public ResponseEntity<byte[]> getCaptcha(HttpSession session) throws IOException {        BufferedImage captchaImage = imageService.createCaptchaImage();        session.setAttribute("captcha", imageService.getCaptchaPosition());        ByteArrayOutputStream baos = new ByteArrayOutputStream();        ImageIO.write(captchaImage, "png", baos);        byte[] imageInByte = baos.toByteArray();        return ResponseEntity.ok()                .header(HttpHeaders.CONTENT_TYPE, MediaType.IMAGE_PNG_VALUE)                .body(imageInByte);    }    @PostMapping("/validate")    public boolean validateCaptcha(@RequestParam int position, HttpSession session) {        Integer captchaPosition = (Integer) session.getAttribute("captcha");        if (captchaPosition != null) {            return Math.abs(captchaPosition - position) <= 5;        }        return false;    }}

在这段代码中,/captcha路由用来生成验证码图片并返回给前端,生成的验证码图片是一个PNG格式的图片。同时,将验证码图片中缺口的位置保存在session中,用来进行后续的验证。/validate路由用来验证用户的操作是否正确。crU28资讯网——每日最新资讯28at.com

ImageService 类crU28资讯网——每日最新资讯28at.com

import org.springframework.stereotype.Service;import java.awt.*;import java.awt.image.BufferedImage;import java.io.IOException;import java.io.InputStream;import java.nio.file.Paths;import javax.imageio.ImageIO;import java.util.Random;@Servicepublic class ImageService {    private int captchaPosition;    public BufferedImage createCaptchaImage() throws IOException {        BufferedImage originalImage = readImageFromResources();        captchaPosition = generateRandomCaptchaPosition(originalImage.getWidth());        BufferedImage captchaImage = new BufferedImage(                originalImage.getWidth(),                originalImage.getHeight(),                originalImage.getType());        int pieceWidth = originalImage.getWidth() / 8;        // 绘制原始图像        Graphics2D graphics2D = captchaImage.createGraphics();        graphics2D.drawImage(originalImage, 0, 0, null);        // 在原始位置绘制一个带形状的片段        graphics2D.setComposite(AlphaComposite.Clear);        graphics2D.fillRoundRect(captchaPosition, captchaImage.getHeight() / 2, pieceWidth, pieceWidth, 10, 10);        graphics2D.dispose();        return captchaImage;    }    private BufferedImage readImageFromResources() throws IOException {        InputStream inputStream = getClass().getResourceAsStream(Paths.get("path_to_resources", "originalImage.png").toString());        return ImageIO.read(inputStream);    }    private static int generateRandomCaptchaPosition(int width) {        Random random = new Random();        return random.nextInt(width / 2) + width / 4; // 将片段定位到图像的中央位置    }    public int getCaptchaPosition() {        return captchaPosition;    }}

这个 ImageService 类实现了 createCaptchaImage 方法,这个方法可以生成一个滑动拼图验证码。首先,它读取了一个原始的图像文件,然后随机生成了一个验证码的位置。接着,它创建了一个新的 BufferedImage 对象,将原始图像绘制到了这个新的对象上,然后在验证码位置上绘制了一个透明的缺口。crU28资讯网——每日最新资讯28at.com

前端:验证码的显示和操作

前端使用HTML和JavaScript来显示验证码图片和处理用户的操作。核心代码如下:crU28资讯网——每日最新资讯28at.com

<img id="captcha" src="api/captcha" /><div id="slider"><div id="knob"></div></div><script>  const slider = document.getElementById('slider');  const knob = document.getElementById('knob');  knob.onmousedown = function(event) {    event.preventDefault();    let shiftX = event.clientX - knob.getBoundingClientRect().left;    document.addEventListener('mousemove', onMouseMove);    document.addEventListener('mouseup', onMouseUp);    function onMouseMove(event) {      let newLeft = event.clientX - shiftX - slider.getBoundingClientRect().left;      if (newLeft < 0) newLeft = 0;      let rightEdge = slider.offsetWidth - knob.offsetWidth;      if (newLeft > rightEdge) newLeft = rightEdge;      knob.style.left = newLeft + 'px';    }    function onMouseUp() {      document.removeEventListener('mouseup', onMouseUp);      document.removeEventListener('mousemove', onMouseMove);      validateCaptcha(parseInt(knob.style.left));    }  };  knob.ondragstart = function() { return false; }  function validateCaptcha(position) {    fetch('api/validate?position=' + position, {method: 'POST'})      .then(response => response.json())      .then(data => { /* process the validation result */ });  }</script>

在这段代码中,显示验证码的元素从后端请求验证码图片。滑动条(<div id="slider">)和滑块(<div id="knob">)用来让用户进行操作。当用户按下滑块时,开始记录滑块的位置,当用户释放滑块时,将滑块的位置发送给后端进行验证。crU28资讯网——每日最新资讯28at.com

实战应用:滑动拼图验证码的应用示例

滑动拼图验证码是一种常见的人机验证工具,主要用于区别用户是人还是机器人。其操作方式通常是,用户通过拖动滑块,将一个图形拼图从初始位置移动到一个预定的位置,如此一来,系统就可以通过这种操作行为来判断用户是否为人类。下面是一个具体的应用示例:crU28资讯网——每日最新资讯28at.com

假如你正在构建一个网站,希望在用户注册或登录时,通过滑动拼图验证码来增强系统的安全防护。在用户填写完用户名和密码后,必须要求他们通过滑动拼图验证码的验证,才能进一步操作。crU28资讯网——每日最新资讯28at.com

  1. 用户首先访问你的网站,并点击注册或登录按钮。
  2. 用户在相应的输入框内填入用户名和密码。
  3. 此时,网站会显示出一个滑动拼图验证码,同时,网站也会提示用户需要通过拖动滑块,将拼图移动到正确的位置。
  4. 用户根据提示操作,移动滑块,将拼图还原到指定位置。
  5. 用户成功完成滑动拼图验证码后,就可以继续注册或登录操作。

引入滑动拼图验证码,可以有效增强你的网站对恶意机器人的防护能力,从而提高用户数据的安全性。同时,这种方式也很友好,用户体验良好,是一种十分实用的人机交互方式。crU28资讯网——每日最新资讯28at.com

本文详细而深入地介绍了滑动拼图验证码的工作原理及其在实战中的应用。文章首先解释了什么是滑动拼图验证码,它如何帮助识别用户是否为人类,提高系统的安全性。然后,文章通过一个具体的实例,详细地描述了如何在用户注册和登录的过程中,使用滑动拼图验证码增强网站的安全防护能力。总结而言,滑动拼图验证码是一种有效且用户体验良好的防护机制,能够针对恶意机器人采取防护措施,提高用户数据的安全性。crU28资讯网——每日最新资讯28at.com

crU28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-87508-0.htmlSpringboot3.x 中实现滑动拼图验证码的全面指南

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Python数据库操作利器:连接Oracle数据库完全指南

下一篇: 小巧便携,静享聆听 森海塞尔推出全新 ACCENTUM 真无线耳机

标签:
  • 热门焦点
  • 一加Ace2 Pro官宣:普及16G内存 引领24G

    一加Ace2 Pro官宣:普及16G内存 引领24G

    一加官方今天继续为本月发布的新机一加Ace2 Pro带来预热,公布了内存方面的信息。“淘汰 8GB ,12GB 起步,16GB 普及,24GB 引领,还有呢?#一加Ace2Pro#,2023 年 8 月,敬请期待。”同时
  • 7月安卓手机性价比榜:努比亚+红魔两款新机入榜

    7月安卓手机性价比榜:努比亚+红魔两款新机入榜

    7月登场的新机有努比亚Z50S Pro和红魔8S Pro,除了三星之外目前唯二的两款搭载超频版骁龙8Gen2处理器的产品,而且努比亚和红魔也一贯有着不错的性价比,所以在本次的性价比榜单
  • 太卷!Redmi MAX 100英寸电视便宜了:12999元买Redmi史上最大屏

    太卷!Redmi MAX 100英寸电视便宜了:12999元买Redmi史上最大屏

    8月5日消息,从小米商城了解到,Redmi MAX 100英寸巨屏电视日前迎来官方优惠,到手价12999元,比发布价便宜了7000元,在大屏电视市场开卷。据了解,Redmi MAX 100
  • 线程通讯的三种方法!通俗易懂

    线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • Flowable工作流引擎的科普与实践

    Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 之家push系统迭代之路

    之家push系统迭代之路

    前言在这个信息爆炸的互联网时代,能够及时准确获取信息是当今社会要解决的关键问题之一。随着之家用户体量和内容规模的不断增大,传统的靠"主动拉"获取信息的方式已不能满足用
  • 华为Mate60标准版细节曝光:经典星环相机模组回归

    华为Mate60标准版细节曝光:经典星环相机模组回归

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • 国行版三星Galaxy Z Fold5/Z Flip5发布 售价7499元起

    国行版三星Galaxy Z Fold5/Z Flip5发布 售价7499元起

    2023年8月3日,三星电子举行Galaxy新品中国发布会,正式在国内推出了新一代折叠屏智能手机三星Galaxy Z Fold5与Galaxy Z Flip5,以及三星Galaxy Tab S9
  • 外交部:美方应停止在网络安全问题上不负责任地指责他国

    外交部:美方应停止在网络安全问题上不负责任地指责他国

      中国外交部今天(16日)举行例行记者会。会上,有记者问,美国情报官员称,他们正在阻拦来自中国以及其他国家的黑客获取相关科研成果。 中方对此有何评论?对此
Top
Baidu
map