滑块验证码实现

2023-05-16

前言

滑块验证码也是生活中常见的,本文会介绍如何实现以及原理。
如果对验证码实现感兴趣的可以看这篇文章:验证码实现 - html页面版
如果对验证码实现感兴趣的可以看这篇文章:验证码实现 - 工具类调用版
在这里插入图片描述

代码实现

滑块验证码主要用到几个属性:clientX,screenX,pageX,offsetX。
代码的解释在注释中已经写的很清楚了,如有更好的实现方式欢迎留言。

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>滑块验证码</title>
    <style>
        * {
            margin: 0px;
            padding: 0px;
            font-family: "微软雅黑";
        }

        .drag {
            width: 300px;
            height: 40px;
            line-height: 40px;
            background-color: #e8e8e8;
            position: relative;
            margin: 0 auto;
        }

        .bg {
            width: 40px;
            height: 100%;
            position: absolute;
            background-color: #75CDF9;
        }

        .text {
            position: absolute;
            width: 100%;
            height: 100%;
            text-align: center;
            user-select: none;
        }

        .btn {
            width: 40px;
            height: 38px;
            position: absolute;
            border: 1px solid #ccc;
            cursor: move;
            font-family: "宋体";
            text-align: center;
            background-color: #fff;
            user-select: none;
            color: #666;
        }
    </style>
</head>

<body>
<div class="drag">
    <div class="bg"></div>
    <div class="text" onselectstart="return false">请拖动滑块解锁</div>
    <div class="btn">&gt;&gt;</div>
</div>
<script>
    //一、定义一个获取DOM元素的方法
    var $ = function (selector) {
            return document.querySelector(selector);
        },
        box = $(".drag"),//容器
        bg = $(".bg"),//背景
        text = $(".text"),//文字
        btn = $(".btn"),//滑块
        success = false,//是否通过验证的标志

        distance = box.offsetWidth - btn.offsetWidth;//滑动成功的宽度(距离)


    //二、给滑块注册鼠标按下事件
    btn.onmousedown = function (e) {
        //1.鼠标按下之前必须清除掉后面设置的过渡属性
        btn.style.transition = "";
        bg.style.transition = "";

        //说明:clientX 事件属性会返回当事件被触发时,鼠标指针向对于浏览器页面(或客户区)的水平坐标。

        //2.当滑块位于初始位置时,得到鼠标按下时的水平位置
        var e = e || window.event;
        var downX = e.clientX;
        //三、给文档注册鼠标移动事件
        document.onmousemove = function (e) {

            var e = e || window.event;//是为了更好的兼容IE浏览器和非ie浏览器。在ie浏览器中,window.event是全局变量,在非ie中,就需要自己传入一个参数来获取event啦,所以就有了var e = e||window.event
            //1.获取鼠标移动后的水平位置
            var moveX = e.clientX;

            //2.得到鼠标水平位置的偏移量(鼠标移动时的位置 - 鼠标按下时的位置)
            var offsetX = moveX - downX;

            //3.在这里判断一下:鼠标水平移动的距离 与 滑动成功的距离 之间的关系
            if (offsetX > distance) {
                offsetX = distance;//如果滑过了终点,就将它停留在终点位置
            } else if (offsetX < 0) {
                offsetX = 0;//如果滑到了起点的左侧,就将它重置为起点位置
            }

            //4.根据鼠标移动的距离来动态设置滑块的偏移量和背景颜色的宽度
            btn.style.left = offsetX + "px";
            bg.style.width = offsetX + "px";

            //如果鼠标的水平移动距离 = 滑动成功的宽度
            if (offsetX == distance) {

                //1.设置滑动成功后的样式
                text.innerHTML = "验证通过";
                text.style.color = "#fff";
                btn.innerHTML = "&radic;";
                btn.style.color = "green";
                bg.style.backgroundColor = "lightgreen";

                //2.设置滑动成功后的状态
                success = true;
                //成功后,清除掉鼠标按下事件和移动事件(因为移动时并不会涉及到鼠标松开事件)
                btn.onmousedown = null;
                document.onmousemove = null;

                //3.成功解锁后的回调函数
                setTimeout(function () {
                    alert('解锁成功!');
                }, 100);
            }
        }

        //四、给文档注册鼠标松开事件
        document.onmouseup = function (e) {
            //如果鼠标松开时,滑到了终点,则验证通过
            if (success) {
                return;
            } else {
                //反之,则将滑块复位(设置了1s的属性过渡效果)
                btn.style.left = 0;
                bg.style.width = 0;
                btn.style.transition = "left 1s ease";
                bg.style.transition = "width 1s ease";
            }
            //只要鼠标松开了,说明此时不需要拖动滑块了,那么就清除鼠标移动和松开事件。
            document.onmousemove = null;
            document.onmouseup = null;
        }


    }
</script>
</body>

</html>

效果图展示

在这里插入图片描述


如果有收获!!! 希望老铁们来个三连,点赞、收藏、转发
创作不易,别忘点个赞,可以让更多的人看到这篇文章,顺便鼓励我写出更好的博客
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

滑块验证码实现 的相关文章

  • Java 基础常见面试题大全

    原因 焦虑 每次去面试更高的职位时候 xff0c 内心总是担忧着那些面试题怎么解答 很多问题在实际工作中并不会遇到 xff0c 没有实际的解决问题经验 xff0c 看过也记不住 让你的Java知识功底更加强悍 xff0c 后面的框架 xff
  • 集合框架(4):HashMap底层原理分析

    文章目录 一 Map接口中常用的方法二 Map接口继承树三 Map底层源码分析1 Map xff1a 2 Map中key value的理解 xff1a 3 面试题 四 HashMap底层源码分析1 在jdk7中2 在jdk8中3 JDK1
  • HashMap中对红黑树、CAS等知识的补充

    目录 一 红黑树1 概念2 图示3 红黑树的特性 二 解决哈希冲突常见方法1 开放定址法2 链接地址3 再哈希法4 建立公共溢出区 三 CAS1 定义2 操作3 Java中CAS操作4 存在的问题5 实际应用 一 红黑树 1 概念 是一种自
  • 集合框架(1):Collection | Iterator | 增强for

    文章目录 Collection接口一 集合框架的概述Collection接口继承树Collection接口中的方法的使用使用迭代器Iterator遍历Collection集合增强for循环遍历集合 文章链接Java语法https blog
  • 解决tomcat启动闪退问题

    通过自己的实践和查阅资料 xff0c 完美解决一下问题 分享给需要的朋友 遇到问题所在 tomcat启动后 xff0c 黑窗口一闪而过 原因分析 缺少JAVA HOME 或者缺少JRE HOME xff0c 说明你的环境变量不对 xff0c
  • 一维数组 | 二维数组 | 内存解析

    文章目录 一 数组1 数组的理解 xff1a 2 数组相关的概念 3 数组的特点 xff1a 4 数组的分类 xff1a 5 数据结构 xff1a 二 一维数组1 一维数组的声明与初始化2 一维数组元素的引用3 数组的属性 xff1a le
  • Java基本语法

    文章目录 关键字与保留字1 关键字2 保留字 标识符1 标识符2 定义合法标识符规则3 Java中的名称命名规范 变量1 变量的概念2 变量作用3 声明变量4 变量分类5 数据类型6 基本数据类型之间的运算 运算符程序流程控制1 顺序结构2
  • Java小型计算器

    通过对程序的编写 xff0c 可以不同位数实现对加减乘除的计算 xff0c 以及对错误答案给出提示 以满足一些大人给小孩出题的困惑 xff0c 此程序可以自己出题 xff0c 自己检测答案 随时随地想做就做 需求 xff1a 1 实现计算器
  • 杨辉三角 | 回形数 | 复制 | 赋值练习题

    目录 杨辉三角回形数格式方阵的实现使用简单数组拓展 xff1a 修改题目 xff0c 实现array2对array1数组的复制 杨辉三角 使用二维数组打印一个10行杨辉三角 span class token keyword public s
  • 水仙花数 | 平闰年 | 斐波那契数列 | 反转单词

    目录 水仙花1 三位数的水仙花2 四位数的水仙花 平闰年斐波那契数列反转句子中单词顺序 水仙花 1 三位数的水仙花 span class token keyword for span span class token punctuation
  • 图像去雾:AOD-Net

    论文地址 xff1a https arxiv org pdf 1707 06543 pdf 相关代码 xff1a GitHub MayankSingal PyTorch Image Dehazing PyTorch implementati
  • 打印三角形 | 所有素数

    目录 3 100的所有素数找出来5 5正方形直角三角形反直角三角形正等腰三角形 xff08 金字塔 xff09 倒立等腰三角形 4 61 1 1 1 3 43 1 5 1 7 43 1 9 1 11 43 43 1 n 若n为99 3 10
  • 冒泡排序 | 快速排序 | 线性查找 | 二分查找等

    目录 排序算法 xff1a 冒泡排序排序算法 xff1a 快速排序数组的复制 反转 查询 xff08 线性查找 二分查找 xff09 排序算法 xff1a 冒泡排序 span class token keyword public span
  • 多线程(1/2)

    文章目录 一 多线程概述1 概念1 1 程序 进程 线程1 2 单核cpu和多核cpu1 3 并行和并发 2 优点3 何时需要 二 继承Thread类1 多线程创建的方式一 xff1a 继承于Thread类2 线程常用方法3 线程的优先级4
  • 多线程(2/2)

    文章目录 一 程序安全的单例模式之懒汉式1 通过同步代码块解决懒汉式单例设计模式的线程安全问题2 通过同步方法解决懒汉式单例设计模式的线程安全问题 二 死锁问题1 死锁的理解 2 说明 三 Lock锁方式解决线程安全问题四 线程的通信1 涉
  • 集合框架(5):LinkHashMap | TreeMap | Properties | Collections工具类

    文章目录 一 LinkedHashMap底层实现原理二 TreeMap1 自然排序2 定制排序 三 Properties四 Collections 工具类1 工具类中常用的方法2 代码演示 文章链接Java语法https blog csdn
  • 集合框架(2):List | ArrayList | LinkedList | Vector的底层源码

    文章目录 一 list比较ArrayList LinkedList Vector三者的异同 xff1f List接口常用方法List遍历及常用方法总结 ArrayList源码分析LinkedList源码分析Vector源码分析ArrayLi
  • 集合框架(3):set | HashSet | LinkedHashSet | TreeSet的底层源码

    文章目录 一 Set练习题 xff1a 在list内去除重复数据值 二 HashSet三 LinkHashSet四 TreeSet1 自然排序2 定制排序 文章链接Java语法https blog csdn net weixin 45606
  • 单例设计模式

    目录 一 设计模式1 理解2 常用设计模式 23种经典的设计模式 二 单例设计模式1 概念 xff1a 2 如何实现 xff1f 3 饿汉式和懒汉式的区别4 应用场景 xff1a 三 模板方法的设计模式1 解决的问题2 举例3 应用场景 一

随机推荐

  • PageHelper实现分页详细版、整合SSM应用

    在项目开发中我们经常要实现分页技术 xff0c 传统的开发过于繁琐 xff0c 这里我们讲解MyBatis中引进的PageHelper实现分页 简单易懂 xff0c 便于上手 xff01 xff01 xff01 参照官网 完成以下分页技术的
  • 最详细IDEA 的安装、配置与使用

    目录 IDEA 的安装 配置与使用一 IntelliJ IDEA 介绍1 IntelliJ IDEA 介绍2 官网 xff1a 3 IDEA 的下载地址 xff1a 官网 4 官网提供的详细使用文档 xff1a 二 windows 下载安装
  • 对遗传算法(GA)的一些理解

    目录 1 遗传算法的原理 2 遗传算法的主要流程 3 对遗传算法中的选择 编码 交叉及变异的理解 1 遗传算法的原理 基因以染色体为载体在种群间得以传播 xff0c 而基因在相当程度上决定了个体的表现型 性状 xff0c 这个传播过程常常伴
  • 最详细IDEA 常用配置、布局说明

    目录 一 创建 Java 工程 xff0c 分析页面布局1 设置显示常见的视图2 工程界面展示3 查看项目配置 二 常用配置 以idea 2019为例 1 设置主题2 设置字体大小 xff08 1 xff09 非代码窗口设置UI样式和字体
  • Springboot整合阿里云短信服务

    文章目录 开通阿里云了解阿里云用户权限操作开通阿里云短信服务添加短信模板添加签名 Springboot整合短信到项目中1 创建一个SpringBoot的项目2 导入依赖3 配置文件4 主启动类5 工具类6 控制器7 业务层8 测试 最好有S
  • 使用JS实现表单验证

    目录 表单页面展示FormCheck jsp CSS样式Register css JavaScript代码FormCheck js 效果图展示 平时我们在注册账号的时候经常看到有提示xxx不得法 xff0c 请重新填写字样 xff0c 本文
  • 对Spring深入的理解 | 概念的总结

    一 Spring的概述 官网 xff1a https spring io projects spring framework overview 官方下载地址 xff1a https docs spring io spring docs 4
  • Spring AOP详解

    1 简述 AOP 概念 AOP xff1a Aspect Oriented Program xff0c 面向 方面 切面的编程 xff1b Filter 过滤器 也是一种 AOP AOP 是一种新的方法论 xff0c 是对传统 OOP Ob
  • Spring IOC详解

    一 IOC的基本概念 1 简述 IOC 概念 IOC Invert Of Control xff0c 控制反转 也成为 DI 依赖注入 其思想是反转资源获取的方向 传统的资源查找方式要求组件向容器发起请求查找资源 作为回应 容器适时的返回资
  • Spring 声明式事务

    文章目录 1 回顾事务2 spring的事务管理3 Spring事务的种类4 基于XML的事务配置1 使用说明2 代码如下 5 基于注解的事务配置1 使用说明2 代码如下 6 基于XML和注解的事务配置代码如下 7 64 Transacti
  • Spring 依赖注入详解

    一 IOC 依赖注入 1 什么是Spring的依赖注入 依赖注入 xff0c 是IOC的一个方面 xff0c 是个通常的概念 xff0c 它有多种解释 这概念是说你不用创建对象 xff0c 而只需要描述它如何被创建 你不在代码里直接组装你的
  • JDBC(1) API详细说明

    目录 一 JDBC概述1 什么是 JDBC2 JDBC API3 JDBC 程序编写步骤 二 用使用 JDBC API1 引入 JDBC 驱动程序1 1 如何获取 JDBC 驱动程序1 2 在Java Project 项目应用中添加数据库驱
  • JDBC(2) 工具类 | PreparedStatement详细说明

    目录 一 JDBC 工具类使用 JDBC API 操作数据库的基本步骤编写工具类 JDBCUtils 二 PreparedStatement1 PreparedStatement 概述2 Statement 的不足3 PreparedSta
  • python: image.paste函数的理解

    目录 image paste函数 举例说明 xff1a image paste函数 python中PIL库中的paste函数的作用为将一张图片覆盖到另一张图片的指定位置去 函数的声明如下 xff1a def paste self im bo
  • JDBC(3)实现通用的增删改查方法

    编写通用的增删改查方法 不明白的可以看代码中注释 xff0c 写的很详细 1 通用的增删改 span class token comment 通用的更新数据库的方法 xff1a insert update delete 语句时 span s
  • JDBC(4)DBCP数据源 | C3P0 数据源

    1 DBCP 数据源 DBCP 是 Apache 软件基金组织下的开源连接池实现 xff0c 该连接池依赖该组织下的另一个开源系统 xff1a Common pool 如需使用该连接池实现 xff0c 应在系统中增加如下两个 jar 文件
  • JDBC(5)DBUtils类详解

    1 DbUtils 类 DbUtils xff1a 提供如关闭连接 装载 JDBC 驱动程序等常规工作的工具类 xff0c 里面的所有方法都是静态的 主要方法如下 xff1a public static void close throws
  • 验证码实现 - html页面版

    前言 图片验证码是我们日常经常用到的 xff0c 本文将介绍如何实现以及其原理 xff0c 并没有过多注重css样式 xff0c 单纯实现验证码功能 如果对滑块验证码感兴趣的可以看这篇文章 xff1a 滑块验证码实现及原理 如果对验证码实现
  • 验证码实现 - 工具类调用版

    前言 图片验证码是我们日常经常用到的 xff0c 本文将介绍如何实现以及其原理 xff0c 以注册页面为例实现功能 如果对滑块验证码感兴趣的可以看这篇文章 xff1a 滑块验证码实现及原理 如果对验证码实现感兴趣的可以看这篇文章 xff1a
  • 滑块验证码实现

    前言 滑块验证码也是生活中常见的 xff0c 本文会介绍如何实现以及原理 如果对验证码实现感兴趣的可以看这篇文章 xff1a 验证码实现 html页面版 如果对验证码实现感兴趣的可以看这篇文章 xff1a 验证码实现 工具类调用版 代码实现