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

常见的验证码

一、短信验证码

前端:

  1. 用户填写手机号,点击按钮发送请求
  2. 用户短信得到验证码后,用户填写表单
  3. 提交 form 表单,进行验证

后台:

  1. 随机生成几位验证码
  2. 并将生成时间、手机号、验证码存储起来,可以存到session、redis、数据库等
  3. 调用短信接口提供的sdk短信发送接口,将验证码发送到指定的手机号上

参考链接

二、图形验证码

前端:

  1. 用户填写手机号,在 input 框失去焦点时,发送获取验证码请求
  2. 得到后台的 base64 编码,并显示出来

<img src={`data:;base64,${verifyCodeUrl}`} onClick={handleGetVerifyCode} />

  1. 提交 form 表单,进行验证
但是它不安全,脚本可以高准确率、快速地识别出答案

类似的还有算数验证码

image.png

三、滑动拼图验证码

根据用户滑动滑块的响应时间,拖拽速度,时间,位置,轨迹,重试次数等验证,相对来说更安全。

  1. 有三张图,带缺口的背景图、拼图、完整的背景图
  2. 操作:

用户的操作:按住滑块,拖动图片至阴影位置,完成验证。

开发人员:

1)对比完整图和背景图的区别,得到阴影位置

2)计算需要滑动的距离:遍历完整图的每一个像素点,利用 getRGB 对比完整图和缺口图哪里有差异,在有差异的时候,返回横坐标,即需要滑动的距离

3)拖动滑块,看效果
image.png

参考链接

http://www.lryc.cn/news/313324.html

相关文章:

  • 11. C语言标准函数库
  • 2016年认证杯SPSSPRO杯数学建模C题(第一阶段)如何有效的抑制校园霸凌事件的发生解题全过程文档及程序
  • 设计模式-抽象工厂模式实践案例
  • 用readproc函数读取进程的状态
  • 在高并发、高性能、高可用 三高项目中如何设计适合实际业务场景的分布式id(一)
  • redis最新版本在Windows系统上的安装
  • 【深度优先】【图论】【C++算法】2045. 到达目的地的第二短时间
  • 思维题(蓝桥杯 填空题 C++)
  • Meta的Llama2模型已上线!但我为何更推荐你从HuggingFace获取?还有Code Llama等你来解锁!
  • CAN总线及通讯的工作原理
  • linux下修改网卡MAC地址
  • 47、WEB攻防——通用漏洞Java反序列化EXP生成数据提取组件安全
  • phpstorm console xdebug
  • Vue template到render过程
  • 【你也能从零基础学会网站开发】Web建站之HTML+CSS入门篇 CSS常用属性
  • Golang 写日志到文件
  • 数字孪生10个技术栈:数据处理的六步骤,以获得可靠数据。
  • 运维随录实战(5)之centos搭建jenkins
  • css clip-path polygon属性实现直角梯形
  • Manz高压清洗机S11-028GCH-High Quality Cleaner 操作使用说明492页
  • 图像处理与视觉感知---期末复习重点(2)
  • 【机器学习】三要素——数据、模型、算法
  • Spring框架Bean对象的五个作用域
  • IoT数据采集网关在企业应用中扮演着关键角色-天拓四方
  • 【动态规划】完全背包
  • 从零开始学习Diffusion Models: Sharon Zhou
  • 全天候购药系统(微信小程序+web后台管理)
  • L2-003 月饼(Java)
  • vue面试--101, 1vue3为啥比vue2好 2 vue3为什么使用proxy
  • 【sgPhotoPlayer】自定义组件:图片预览,支持点击放大、缩小、旋转图片