文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JavaScript如何实现拼图式滑块验证功能

2023-07-02 00:08

关注

这篇文章主要介绍“JavaScript如何实现拼图式滑块验证功能”,在日常操作中,相信很多人在JavaScript如何实现拼图式滑块验证功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript如何实现拼图式滑块验证功能”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

演示

JavaScript如何实现拼图式滑块验证功能

前戏

滑块验证码是在网站、APP等应用中常见的一种验证方式,通过按照一定规则滑动滑块到指定位置完成验证,才可以进行下一步操作。滑块验证码有两种设计,一种是在滑动框内“一滑到底”即完成验证的,还有一种是滑动滑块拼合拼图完成验证的。由于拼图式的滑块验证码安全性更高,趣味性更强,所以多数网站或APP都选择了拼图式的滑块验证码。

拼图式的滑块验证码在业务应用中有三种展现形式,触发式、嵌入式和弹出式。触发式即鼠标光标移入验证条后才显示验证拼图,不影响网页原有的排版。嵌入式即拼图验证区域直接嵌入展示在网页,清晰直观,便于用户使用。弹出式一般可以绑定自有验证方式,点击验证后才弹出滑动验证码,比如用户输入用户名和密码,点击登录后,页面弹出滑块验证码。

源码介绍

主页样式设计

  .bxs-row {            margin-bottom:12px;        }        .logo-box {            width:404px;            margin:120px auto;            border:1px solid #e5e5e5;            border-radius:4px;            box-shadow:0 4px 18px rgba(0,0,0,0.2);            position:relative;            overflow:hidden;            height:360px;        }        .login {            position:absolute;            width:320px;left:0;            top:0;            padding: 42px 42px 36px;            transition:all 0.8s;        }        .username,.password,.btn {            height: 44px;            width: 100%;            padding: 0 10px;            border: 1px solid #9da3a6;            background: #fff;            text-overflow: ellipsis;            -webkit-box-sizing: border-box;            -moz-box-sizing: border-box;            box-sizing: border-box;            -webkit-border-radius: 4px;            -moz-border-radius: 4px;            -khtml-border-radius: 4px;            border-radius: 4px;            -webkit-box-shadow: none;            -moz-box-shadow: none;            box-shadow: none;            color: #000;            font-size: 1em;            font-family: Helvetica,Arial,sans-serif;            font-weight: 400;            direction: ltr;            font-size:13px;        }        .submit {            background-color: #0070ba;            color:#fff;            border:1px solid #0070ba;        }        .submit:hover {            background-color:#005ea6;        }        .verBox {            position:absolute;            width:100%;            text-align:center;            left:404px;            top:0;            opacity:0;            transition:all 0.8s;            padding-top:55px;        }        .err {            margin:12px 0 0;            line-height:12px;            height:12px;            font-size:12px;            color:red;        }

滑块验证部分

这里使用了一个工具img_ver.js网上都是关于vue的没有这个简单

imgVer({            el:'$("#imgVer")',            width:'260',            height:'116',            img:[                'images/ver-1.png',                'images/ver-2.png',            ],            success:function () {                //alert('执行登录函数');                $(".login").css({                    "left":"0",                    "opacity":"1"                });                $(".verBox").css({                    "left":"404px",                    "opacity":"0"                });                $(".tips").html('你是不是不知道账号密码!???');                $("#logo").attr("src",'images/login-err.png')            },            error:function () {                //alert('错误什么都不执行')            }        });

img_ver内部

滑块移动和验证部分

  ctx.moveTo(X, Y);    ctx.lineTo(X + d, Y);    ctx.bezierCurveTo(X + d, Y - d, X + 2 * d, Y - d, X + 2 * d, Y);    ctx.lineTo(X + 3 * d, Y);    ctx.lineTo(X + 3 * d, Y + d);    ctx.bezierCurveTo(X + 2 * d, Y + d, X + 2 * d, Y + 2 * d, X + 3 * d, Y + 2 * d);    ctx.lineTo(X + 3 * d, Y + 3 * d);    ctx.lineTo(X, Y + 3 * d); ctx_l.moveTo(X, Y);    ctx_l.lineTo(X + d, Y);    ctx_l.bezierCurveTo(X + d, Y - d, X + 2 * d, Y - d, X + 2 * d, Y);    ctx_l.lineTo(X + 3 * d, Y);    ctx_l.lineTo(X + 3 * d, Y + d);    ctx_l.bezierCurveTo(X + 2 * d, Y + d, X + 2 * d, Y + 2 * d, X + 3 * d, Y + 2 * d);    ctx_l.lineTo(X + 3 * d, Y + 3 * d);    ctx_l.lineTo(X, Y + 3 * d);ctx_s.moveTo(X, Y);    ctx_s.lineTo(X + d, Y);    ctx_s.bezierCurveTo(X + d, Y - d, X + 2 * d, Y - d, X + 2 * d, Y);    ctx_s.lineTo(X + 3 * d, Y);    ctx_s.lineTo(X + 3 * d, Y + d);    ctx_s.bezierCurveTo(X + 2 * d, Y + d, X + 2 * d, Y + 2 * d, X + 3 * d, Y + 2 * d);    ctx_s.lineTo(X + 3 * d, Y + 3 * d);    ctx_s.lineTo(X, Y + 3 * d);

到此,关于“JavaScript如何实现拼图式滑块验证功能”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯