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

微信小程序-滑动拼图安全验证

滑动拼图验证组件1. 前提介绍2. 最终实现效果图3. 封装验证组件并使用1.编写组件2.引入并使用4. 总结1. 前提介绍本项目是应用taro框架使用Canvas 画布组件微信开发文档来实现的注此组件目前是纯前端校验没涉及后端2. 最终实现效果图3. 封装验证组件并使用1.编写组件话不多说直接上代码viewtemplate!-- 滑动验证弹窗 --viewclassmask puzzleVerify-maskv-ifvisible:catch-movetrueviewclasscontiner_box puzzleVerify-content!-- 弹窗头部 --viewclassmodal-headertextclassmodal-title安全验证/textviewclassmodal-closetaponCloseimagestylewidth: 100%; height: 100%srchttps://yunqi-dy-public.tos-cn-beijing.volces.com/files/20260317/13bb166726b5446fba307934cdb0bf71.png//view/viewviewclasspuzzleVerify-box!-- 提示文字 --viewclasspuzzle-tiptextclasstip-text拖动滑块完成拼图验证/text/view!-- 拼图图片部分 --viewclasscanvas_imgidcanvas_img:style{ position: relative, zIndex: 0 }!-- 背景图片 --!--canvas :style{ width: canvas_width px, height: canvas_height px, border: 1rpx solid transparent, }idfirstCanvastype2d/canvas--canvasidfirstCanvastype2d/canvas!-- 被抠方块 --viewclasscanvas_view:style{ left: canfile_x px, top: canfile_y px, position: absolute, zIndex: 3, }/view!-- 可移动空格 --imageclasscanfile_image:style{ top: canfile_y px, left: (slide_clientX canvas_width - 50 ? canvas_width - 50 : slide_clientX) px, position: absolute, zIndex: 4, }:srccanfile_image/imageclassrefresg-iconsrchttps://yunqi-dy-public.tos-cn-beijing.volces.com/files/20260317/27a0a2ac09074b62b941f0e1288ed3b7.pngtaponDrawCanvas//view/view!-- 滑块 --viewclasscanvas-slideviewclasscanvas-slide-width:style{ width: [2, 3].includes(slide_status) ? 100% : slide_clientX canvas_width ? canvas_width : slide_clientX px, background: slide_status 2 ? #52CCBA : slide_status 3 ? #F57A7A : , }/viewview v-ifslide_status 0 || slide_status 1classcanvas-slide-btn fcctouchstartonSliderStarttouchmoveonSliderMovetouchendonSliderEnd:style{ left: slide_clientX canvas_width ? canvas_width : slide_clientX px, }view→/view/viewviewclasscanvas-slide-tipv-ifslide_status 0 || slide_status 1拖动左边滑块完成上方拼图/viewview v-elseclasscanvas-slide-tip canvas-slide-tip2{{slide_status2?验证成功:验证失败请重试}}/view/view/view/view/templatescriptimportTaro fromtarojs/taro;import./puzzleVerify.scss;exportdefault{props:{value:{type: Boolean, default: false,},},data(){return{visible: false, canvas_width:0, canvas_height:0, slidebel: false, //滑动弹窗 canfile_image:, //裁剪图片 canfile_x:, //被抠方块的水平位置 canfile_y:, //被抠方块的垂直位置 slide_clientX:0, //移动位置 slide_status:0, //0 停止操作1触发长按2正确3错误 puzzleImages:[https://i.postimg.cc/JDjqt4tw/bg1.jpg,https://i.postimg.cc/3J5HYcPP/bg4.png,https://i.postimg.cc/zBs4DyPQ/bg2.png,],};}, watch:{value(newVal){this.visiblenewVal;if(newVal){setTimeout((){const queryTaro.createSelectorQuery();query .select(#canvas_img).boundingClientRect((rect){if(rect){console.log(rect, rect);this.canvas_widthrect.width;this.canvas_heightMath.floor(rect.width *0.5);// 宽高比2:1 setTimeout((){this.onDrawCanvas();},200);}}).exec((rect){});},500);}},}, methods:{onClose(){this.$emit(input,false);}, // 画布 onDrawCanvas(e){var thatthis;//获取图片条数的随机数 var imgIndexMath.floor(Math.random()* this.puzzleImages.length);this.canfile_xMath.round(Math.random()*(this.canvas_width -120)60);this.canfile_yMath.round(Math.random()*((this.canvas_width *13)/28-60));this.canfile_image;Taro.createSelectorQuery().select(#firstCanvas)// 在 WXML 中填入的id.fields({node: true, size:true}).exec((res){// Canvas 对象 const canvasres[0].node;// 渲染上下文 const ctxcanvas.getContext(2d);// Canvas 画布的实际绘制宽高 const widthres[0].width;const heightres[0].height;// 初始化画布大小 const dprwx.getWindowInfo().pixelRatio;canvas.widthwidth * dpr;canvas.heightheight * dpr;ctx.scale(dpr, dpr);const imagecanvas.createImage();// 设置图片src image.srcthis.puzzleImages[imgIndex];// 图片加载完成回调 image.onload(){// 将图片完整绘制到 canvas 上 ctx.drawImage(image,0,0, width, height);// 绘制完成后可以添加一些调试信息 console.log(图片绘制完成尺寸:, image.width, image.height);console.log(Canvas尺寸:, width, height);};//一定要加延时器不然图片会生成失败 setTimeout((){// 生成图片 Taro.canvasToTempFilePath({canvas, x: that.canfile_x, y: that.canfile_y, width:60, height:60, success:(res){// 生成的图片临时文件路径 that.canfile_imageres.tempFilePath;console.log(tempFilePath, that.canfile_image);},}, this);},500);});}, // 滑动开始 onSliderStart(e){this.slide_status1;}, // 滑动中 onSliderMove(e){this.slide_clientXe.touches[0].clientX -301?0:e.touches[0].clientX -30;}, //滑动结束 onSliderEnd(e){var thatthis;var cliextX;var maxXthis.canvas_width -30;if(that.slide_clientX1){that.slide_status0;returnfalse;}if(that.slide_clientXmaxX){cliextXmaxX;}else{cliextXthat.slide_clientX;}if(that.canfile_x 5cliextXthat.canfile_x -5cliextX){that.slide_status2;that.slide_clientXthat.canfile_x;setTimeout(function(){that.slidebelfalse;},500);wx.showToast({icon:success, title:验证成功,});this.$emit(onSuccess);this.onClose();}else{that.slide_status3;}setTimeout(function(){that.slide_status0;that.slide_clientX0;},500);},},};/script/* 拼图滑动验证 */ .puzzleVerify-mask{.puzzleVerify-content{position: relative;padding: 50rpx 30rpx!important;box-sizing: border-box;}/* 弹窗头部 */ .modal-header{display: flex;align-items: center;justify-content: space-between;padding: 0rpx 0rpx 30rpx;border-bottom: 2rpx solid#f5f5f5;.modal-title{font-size: 32rpx;font-weight:600;color:#333333;}.modal-close{width: 48rpx;height: 48rpx;}}.puzzleVerify-box{padding-top: 30rpx;.puzzle-tip{text-align: center;margin-bottom: 24rpx;.tip-text{font-size: 28rpx;color:#666666;}}.canvas_img{position: relative;width:100%;height: 300rpx;margin-bottom: 40rpx;border-radius: 12rpx;overflow: hidden;background:#f8f9fa;}#firstCanvas {z-index:1!important;width:100%;height:100%;}/* 被抠的空格 */ .canvas_view{width: 50px;height: 50px;position: absolute;background: rgba(0,0,0,0.6);z-index:2;box-shadow:005px 2px rgba(255,255,255,0.5);}/* 移动的空格 */ .canfile_image{width: 50px;height: 50px;position: absolute;left:0;z-index:3;box-shadow: 0px 0px 15px rgba(0,0,0,0.8);box-sizing: border-box;}.canfile_image::before{content:;position: absolute;width:100%;height:100%;box-shadow:008px 5px rgba(255,255,255,0.8)inset;}.refresg-icon{position: absolute;top: 20rpx;right: 20rpx;width: 48rpx;height: 48rpx;z-index:5;}}}.canvas-slide{width:100%;height: 60rpx;background:#e5e5e5;text-align: center;position: relative;font-size: 26rpx;overflow: hidden;/* 滑条上滑块经过的部分 */ .canvas-slide-width{position: absolute;left:0;top:0;height: 60rpx;background-color:#1991fa;width:0;border-top: 1px solid#ddd;border-bottom: 1px solid#ddd;z-index:2;}/* 滑块 */ .canvas-slide-btn{width: 80rpx;height: 60rpx;background-color:#1991fa;font-size: 36rpx;font-weight:700;position: absolute;left:0;top:0;border: 1px solid#ddd;color:#fff;box-shadow:0010px rgba(0,0,0,0.3);z-index:2;}.canvas-slide-tip{width:100%;position: absolute;top:50%;left:50%;transform: translate(-50%, -50%);text-align: center;font-size: 24rpx;color:#fff;transition: color0.3s ease;z-index:1;}.canvas-slide-tip.canvas-slide-tip2{z-index:4;}}2.引入并使用templateviewview taponShowVerity获取验证码/viewpuzzleVerify v-modelisShowVerifyonSuccessonVerifySuccess//view/templatescriptimportpuzzleVerify from/components/puzzleVerify/puzzleVerify.vue;exportdefault{components:{puzzleVerify},data(){return{isShowVerify: false, //安全校验弹窗};}, methods:{onVerifySuccess(){console.log(验证通过-------------);},onShowVerity(){this.isShowVerifytrue;},}};/script4. 总结注上面的方式是有应用到实际项目当中去的正常获取流程是没问题的如果在开发在过程中遇到问题可以发出来一起交流呢

相关文章:

微信小程序-滑动拼图安全验证

滑动拼图验证组件1. 前提介绍2. 最终实现效果图3. 封装验证组件并使用1.编写组件2.引入并使用4. 总结1. 前提介绍 本项目是应用taro框架,使用Canvas 画布组件微信开发文档,来实现的 (注:此组件目前是纯前端校验,没涉及…...

Kimi-VL-A3B-Thinking快速上手:不写代码,用Web界面完成图文推理全流程

Kimi-VL-A3B-Thinking快速上手:不写代码,用Web界面完成图文推理全流程 你是不是经常遇到这样的场景:拿到一张复杂的图表,想快速提取里面的关键信息;或者看到一张产品图,想知道它的具体参数和特点&#xff…...

从Bezier到NURBS:Halcon中样条曲线拟合的技术演进与选型建议

从Bezier到NURBS:Halcon中样条曲线拟合的技术演进与选型建议 在工业视觉检测领域,曲线拟合算法的选择直接影响着测量精度和系统稳定性。Halcon作为计算机视觉领域的标杆工具,其曲线拟合技术经历了从简单多项式到NURBS(非均匀有理B…...

ruoyi-vue-pro ERP系统实战:5分钟搞定采购模块数据库设计与业务逻辑

Ruoyi-Vue-Pro ERP采购模块实战:从数据库设计到业务联调全解析 上个月接手一个制造业客户的ERP系统改造项目时,他们的采购主管抱怨现有系统存在三个致命问题:供应商信息混乱导致比价困难、采购订单与入库单脱节造成对账耗时、库存更新延迟引发…...

AI|大模型数学能力评估实战

1. 大模型数学能力评估的意义 评估大模型的数学能力,本质上是在测试它的逻辑思维和计算精度。这就像给一个学生做数学考试,不仅要看他能不能算出正确答案,还要观察他的解题思路是否清晰、步骤是否合理。在实际应用中,大模型的数学…...

Miniconda-Python3.10镜像效果展示:一键创建多个独立Python环境

Miniconda-Python3.10镜像效果展示:一键创建多个独立Python环境 1. 为什么需要独立的Python环境 在Python开发中,我们经常会遇到这样的困扰:不同项目依赖的库版本不同,导致冲突和兼容性问题。比如: 项目A需要Tensor…...

EfficientNet解析:复合缩放如何重塑轻量级网络性能

1. 从MobileNet到EfficientNet的进化之路 2017年,当Google首次推出MobileNet时,整个计算机视觉领域都为之一振。这个专为移动端设计的轻量级网络,用深度可分离卷积(Depthwise Separable Convolution)取代传统卷积&…...

Meshlab实用操作指南:从STL处理到点云化

1. Meshlab入门:为什么选择它处理STL文件? 如果你经常接触3D模型,尤其是工业设计、逆向工程或者3D打印领域,STL格式的文件对你来说一定不陌生。这种三角网格文件格式简单通用,但直接处理起来却不太方便——这时候Meshl…...

天问语音模块LU-ASR PRO语音替换全攻略:从MP3转换到一键烧录

天问语音模块LU-ASR PRO语音替换全攻略:从MP3转换到一键烧录 在智能硬件开发中,语音交互功能正变得越来越普及。天问语音模块LU-ASR PRO作为一款性能优异的语音识别模块,被广泛应用于各类智能设备中。本文将详细介绍如何对模块中的默认语音进…...

Android预装APK的V2签名失效问题分析与解决策略

1. 为什么V2签名在预装时会失效? 这个问题困扰过不少Android开发者。我去年在给某智能手表项目预装系统应用时就踩过这个坑,当时GTS测试总是报签名错误,折腾了一周才发现是预装方式的问题。先说说V2签名的特点:它会对整个APK文件进…...

岚图上市:成央国企高端新能源汽车第一股 武汉从造车向造链升级

雷递网 雷建平 3月19日岚图汽车(07489.HK)今日在港交所上市,成为“央国企高端新能源汽车第一股”。岚图汽车也成为继蔚小理、零跑汽车、奇瑞汽车之后,港股市场迎来的又一股重要的新能源造车力量。放眼全局,岚图也是华中…...

百度富文本编辑器在国产化信创环境中如何处理PPT导入?

教育网站CMS系统Word导入功能开发实录——C#程序员视角 一、需求拆解与前期调研 作为独立外包开发者,我首先与教育机构的产品经理进行了3次需求对齐会议,明确核心痛点: 教师群体:需将备课文档(含公式、表格、教学图…...

TSP求解器大比拼:Concorde vs LKH,哪个更适合你的项目?

TSP求解器深度评测:Concorde与LKH的核心差异与工程实践指南 当面对物流路径规划、芯片布线或无人机巡检路线优化等实际工程问题时,旅行商问题(TSP)的求解效率直接关系到业务成本。本文将带您深入两个业界标杆求解器——Concorde与…...

网页版百度UM编辑器能否跨平台粘贴Excel表格数据?

Word图片一键转存功能开发全记录 技术调研与选型 作为项目前端负责人,我近期专注于解决Word文档粘贴到UEditor时图片自动转存的问题。经过对同类方案的对比分析,确定以下技术路线: 前端技术栈 Vue2.6.14 UEditor 1.4.3Axios 0.21.1&…...

REST API的隐性成本有多高?——基于百万QPS压测的带宽、GC、内存占用三维对比报告

第一章:REST API的隐性成本有多高?——基于百万QPS压测的带宽、GC、内存占用三维对比报告在真实高并发场景下,REST API 的表层简洁性常掩盖其底层资源开销。我们对三类典型服务(Go net/http、Spring Boot WebMvc、Node.js Express…...

LlamaFirewall大模型防火墙框架:构建安全AI代理的开源护栏系统

1. LlamaFirewall框架的核心价值与应用场景 当大模型技术逐渐渗透到各行各业时,安全问题就像悬在头顶的达摩克利斯之剑。我去年参与过一个金融领域的AI客服项目,上线第三天就遭遇了精心设计的提示词注入攻击——攻击者用看似普通的用户提问,成…...

嵌入式开发实战:SPI回环测试完整流程与常见问题排查(基于Linux内核)

嵌入式Linux SPI回环测试全流程解析:从原理到实战 在嵌入式系统开发中,SPI(Serial Peripheral Interface)总线因其高速、全双工的特性,成为连接传感器、存储设备和显示模块的首选方案。而回环测试作为验证SPI通信可靠性…...

ARM架构下Python连接PostgreSQL的坑:手把手解决Aarch64安装psycopg2-binary的依赖问题

ARM架构下Python连接PostgreSQL的深度解决方案:Aarch64平台psycopg2-binary依赖问题全解析 在边缘计算和物联网设备快速普及的今天,ARM架构处理器凭借其低功耗、高性能的特性,正成为许多应用场景的首选。然而,当Python开发者尝试在…...

为什么93%的MCP项目在上线3个月后成本翻倍?揭秘本地数据库连接器的3层“幽灵开销”与零代码修复方案

第一章:MCP服务器本地数据库连接器成本失控的真相MCP(Microservice Coordination Platform)服务器在部署本地数据库连接器时,常因连接池配置失当、连接泄漏与无感知重连机制导致资源持续占用,最终引发云资源账单异常飙…...

别再死记HashMap了!多线程死循环、数据丢失,这些坑90%的人都踩过

面试时被问HashMap,你是不是也这样? “底层是数组链表,JDK1.8加了红黑树,扩容阈值是容量负载因子……”背得滚瓜烂熟,却被面试官追问一句“多线程下为什么会死循环”,瞬间卡壳。 更扎心的是:工作…...

风电光伏的场景生成与消减-matlab代码 可利用蒙特卡洛模拟或者拉丁超立方生成光伏和风电出力场景

风电光伏的场景生成与消减-matlab代码 可利用蒙特卡洛模拟或者拉丁超立方生成光伏和风电出力场景,并采用快速前推法或同步回代消除法进行削减,可以对生成场景数和削减数据进行修改,下图展示的为1000个场景削减至10个典型场景,并获…...

[Hello-CTF]RCE-labs靶场:从零到一的Docker化实战指南

1. 为什么你需要一个本地化的RCE靶场 作为一个刚接触CTF的新手,我最初在练习远程代码执行(RCE)漏洞时总是束手束脚——要么找不到合适的在线靶场,要么好不容易找到的靶场环境不稳定。直到后来发现用Docker搭建本地靶场这个方案&am…...

图像匹配避坑指南:NCC算法在工业检测中的实战应用

工业视觉实战:NCC算法在缺陷检测中的高阶应用与调优策略 工业生产线上的视觉检测系统正面临前所未有的挑战——每分钟处理上千件产品的同时,还要确保缺陷识别准确率超过99.9%。在这个追求极致效率与精度的领域,归一化互相关(NCC)算法以其独特…...

WANLSHOP多终端电商系统:FastAdmin+Uni-APP构建私域流量新生态

1. 为什么选择WANLSHOP构建私域流量生态 这两年做电商的朋友们应该都深有体会,公域流量越来越贵,获客成本高得吓人。我去年帮一个服装品牌做系统升级时,他们天猫店的单个客户获取成本已经突破200元。这时候,WANLSHOP这套基于FastA…...

OpenClaw未来可能方向研究报告

2026年,AI 行业的竞争逻辑正在发生根本性的转向。当多数产品还在卷大语言模型的对话流畅度,比拼谁能给出更完美的文本回答时,OpenClaw 已经走出了一条完全不同的路。关注公众号:【互联互通社区】,回复【claw017】获取全…...

Qwen-Image-Edit-2511真实体验:亲测换装、去水印,效果太自然了

Qwen-Image-Edit-2511真实体验:亲测换装、去水印,效果太自然了 作为一名长期被Photoshop折磨的设计师,当我第一次用Qwen-Image-Edit-2511完成换装操作时,那种震撼感至今难忘——原本需要3小时精修的模特换装图,现在30…...

OpenClaw节能模式:Qwen3-32B在笔记本电脑上的续航优化方案

OpenClaw节能模式:Qwen3-32B在笔记本电脑上的续航优化方案 1. 为什么需要关注OpenClaw的能耗问题 去年夏天的一次出差经历让我深刻意识到OpenClaw能耗管理的重要性。当时我正用笔记本电脑运行一个基于Qwen3-32B的自动化数据处理流程,结果不到两小时电池…...

国产GIS路线制图神器!无需第三方工具,Pro版一体化搞定路线标绘与出图

在应急疏散、抢险路线、赛道规划、景点导览等场景中,快速生成一张清晰、专业、规范的可视化路线图是方案汇报与现场执行的关键。今天,我们通过 Bigemap Pro版 软件为大家带来一套完整的路线图手绘制作方案。本教程所有操作均在 Bigemap Pro 版内一体化完…...

HX711称重模块在GD32E230上的驱动实现与校准

1. HX711称重传感器模块技术解析与GD32E230平台驱动实现1.1 模块核心特性与工程定位HX711是一款专为高精度电子秤系统设计的24位模数转换器(ADC)芯片,其核心价值在于将微弱的桥式传感器信号进行高增益、低噪声放大与精确数字化。该模块并非通…...

Ostrakon-VL-8B模型原理浅析:理解视觉-语言多模态融合机制

Ostrakon-VL-8B模型原理浅析:理解视觉-语言多模态融合机制 你是不是也好奇,那些能看懂图片、还能跟你聊天的AI模型,到底是怎么工作的?比如你给它一张猫在沙发上的照片,它不仅能认出猫和沙发,还能告诉你“一…...