首页 文章详情

一个非常好的行为验证码Java开源项目!

Java后端编程 | 595 2021-02-26 17:46 0 0 0
UniSMS (合一短信)

项目介绍

行为验证码采用嵌入式集成方式,接入方便,安全,高效。抛弃了传统字符型验证码展示-填写字符-比对答案的流程,采用验证码展示-采集用户行为-分析用户行为流程,用户只需要产生指定的行为轨迹,不需要键盘手动输入,极大优化了传统验证码用户体验不佳的问题;同时,快速、准确的返回人机判定结果。目前对外提供两种类型的验证码,其中包含滑动拼图、文字点选。如下图所示。若希望不影响原UI布局,可采用弹出式交互。

滑动拼图

点选文字

概念术语描述

术语描述
验证码类型1)滑动拼图 blockPuzzle 2)文字点选 clickWord
验证用户拖动/点击一次验证码拼图即视为一次“验证”,不论拼图/点击是否正确
二次校验验证数据随表单提交到后台后,后台需要调用captchaService.verification做二次校验。目的是核实验证数据的有效性。

交互流程

① 用户访问应用页面,请求显示行为验证码
② 用户按照提示要求完成验证码拼图/点击
③ 用户提交表单,前端将第二步的输出一同提交到后台
④ 验证数据随表单提交到后台后,后台需要调用captchaService.verification做二次校验。
⑤ 第4步返回校验通过/失败到产品应用后端,再返回到前端。如下图所示。

时序图

目录结构

├─core
│ ├─captcha    java核心源码
│ └─captcha-spring-boot-starter    springboot快速启动
├─images       效果图
├─service
│ ├─springboot    后端为springboot项目示例
│ └─springmvc    后端为springmvc非springboot项目示例
└─view       多语言客户端示例
 ├─android    原生android实现示例
 ├─flutter    flutter实现示例
 ├─html    原生html实现示例
 ├─ios    原生ios实现示例
 ├─uni-app    uni-app实现示例
 └─vue    vue实现示例

在线体验

1.1 电脑在线体验:https://captcha.anji-plus.com/

1.2 微信小程序和H5在线体验(基于uni-app实现)

微信小程序
 微信小程序Demo

项目地址

如何获取?

1. 点击关注公众号「GitHub科技」;
2. 在下面公众号后台回复关键字「
113


点击👆👆卡片

关注后回复「113

good-icon 0
favorite-icon 0
收藏
回复数量: 0
    暂无评论~~
    Ctrl+Enter