行为式验证码java_GitHub - jiankunking/captcha: 行为验证码(滑动拼图、点选文字),前后端(java)交互,包含h5/Android/IOS/flutter/uni-a...

本文介绍了一个基于Java的行为式验证码项目,包括滑动拼图和文字点选两种类型,旨在优化用户体验并提高人机判断效率。该项目支持微信小程序、H5、Android、iOS、Flutter和Uni-app等平台的交互,并提供了详细接入文档和示例代码。
摘要由CSDN通过智能技术生成

1 在线体验

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

如果图片未能正常展示,可查看码云,和github同步 码云

   f9056407ac350708e74c1dc4afdecfe0.png      

微信小程序Demo               uni-app H5 demo

2 功能概述

2.1 组件介绍

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

   d4f421af3a50fcc34296f875ff7b6e8e.png     f692aa6256ccce47db54dc31da6aa2ba.png

图1-1 滑动拼图(水印自定义)               图1-2 文字点选(水印自定义)

2.2 概念术语描述

术语

描述

验证码类型

1)滑动拼图 blockPuzzle 2)文字点选 clickWord

验证

用户拖动/点击一次验证码拼图即视为一次“验证”,不论拼图/点击是否正确

二次校验

验证数据随表单提交到后台后,后台需要调用captchaService.verification做二次校验。目的是核实验证数据的有效性。

3 交互流程

①用户访问应用页面,请求显示行为验证码

②用户按照提示要求完成验证码拼图/点击

③用户提交表单,前端将第二步的输出一同提交到后台

④验证数据随表单提交到后台后,后台需要调用captchaService.verification做二次校验。

⑤第4步返回校验通过/失败到产品应用后端,再返回到前端。如下图所示。

f0d6f00a4649224bba3919de35f9fe9c.png

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实现示例

5 接入文档

5.1 本地启动

第一步,启动后端,导入Eclipse或者Intellij,启动service/springboot的StartApplication。社区底图库

第二步,启动前端,使用visual code打开文件夹view/vue,npm install后npm run dev,浏览器登录

npm install

npm run dev

DONE Compiled successfully in 29587ms 12:06:38

I Your application is running here: http://localhost:8081

详细的前后端接入文档,后端示例代码service目录下,前端示例代码view目录下。

6 近期计划

6.1 增加weex示例

6.2 增加ReactNative示例

6 技术支持微信群

开源不易,劳烦各位star ☺

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值