diff --git a/readme.md b/readme.md
index 3905025..aab133e 100644
--- a/readme.md
+++ b/readme.md
@@ -1,376 +1,100 @@
-这是一个行为验证码的实现
-
-## [在线体验](https://www.tianai.cloud)
-
+# 这是一个滑块验证码的实现
+## [在线体验](http://101.42.239.82:8080/)
## 验证码demo移步 [tianai-captcha-demo](https://gitee.com/tianai/tianai-captcha-demo)
-
+## 不说废话,直接上成品

-
-
-
-
-
-
-
+
+
-## 简单介绍
-- tianai-captcha 目前支持的行为验证码类型
- - 滑块验证码
- - 旋转验证码
- - 滑动还原验证码
- - 文字点选验证码
- - 后面会陆续支持市面上更多好玩的验证码玩法... 敬请期待
-## 快速上手
+- 该滑块验证码实现了 普通图片和 **webp**图片两种格式
+- java获取滑块验证码例子
-如果是SpringBoot开发者可直接使用SpringBoot快速启动器[tianai-captcha-springboot-starter](https://gitee.com/tianai/tianai-captcha-springboot-starter)
-
-### 1. 导入xml
+## 快速上手
+- 如果是SpringBoot开发者可直接使用SpringBoot快速启动器[tianai-captcha-springboot-starter](https://gitee.com/tianai/tianai-captcha-springboot-starter)
+1. 导入xml
```xml
-
-
- cloud.tianai.captcha
- tianai-captcha
- 1.3.2
-
+
+
+ cloud.tianai.captcha
+ tianai-captcha
+ 1.2.3
+
```
-
-### 2. 使用 `ImageCaptchaGenerator`生成器生成验证码
-
+2. 使用 `SliderCaptchaTemplate`获取滑块验证码
```java
-package example.readme;
+public static void main(String[] args) throws InterruptedException {
+ SliderCaptchaResourceManager sliderCaptchaResourceManager = new DefaultSliderCaptchaResourceManager();
+ DefaultSliderCaptchaTemplate sliderCaptchaTemplate = new DefaultSliderCaptchaTemplate(sliderCaptchaResourceManager, true);
+ // 生成滑块图片
+ SliderCaptchaInfo slideImageInfo = sliderCaptchaTemplate.getSlideImageInfo();
+ // 获取背景图片的base64
+ String backgroundImage = slideImageInfo.getBackgroundImage();
+ // 获取滑块图片
+ slideImageInfo.getSliderImage();
+ // 获取滑块被背景图片的百分比, (校验图片使用)
+ Float xPercent = slideImageInfo.getXPercent();
-import cloud.tianai.captcha.common.constant.CaptchaTypeConstant;
-import cloud.tianai.captcha.generator.ImageCaptchaGenerator;
-import cloud.tianai.captcha.generator.common.model.dto.ImageCaptchaInfo;
-import cloud.tianai.captcha.generator.impl.MultiImageCaptchaGenerator;
-import cloud.tianai.captcha.resource.ImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.impl.DefaultImageCaptchaResourceManager;
-import cloud.tianai.captcha.validator.ImageCaptchaValidator;
-import cloud.tianai.captcha.validator.impl.BasicCaptchaTrackValidator;
-
-import java.util.Map;
-
-public class Test {
- public static void main(String[] args) throws InterruptedException {
- ImageCaptchaResourceManager imageCaptchaResourceManager = new DefaultImageCaptchaResourceManager();
- ImageCaptchaGenerator imageCaptchaGenerator = new MultiImageCaptchaGenerator(imageCaptchaResourceManager).init(true);
- /*
- 生成滑块验证码图片, 可选项
- SLIDER (滑块验证码)
- ROTATE (旋转验证码)
- CONCAT (滑动还原验证码)
- WORD_IMAGE_CLICK (文字点选验证码)
-
- 更多验证码支持 详见 cloud.tianai.captcha.common.constant.CaptchaTypeConstant
- */
- ImageCaptchaInfo imageCaptchaInfo = imageCaptchaGenerator.generateCaptchaImage(CaptchaTypeConstant.SLIDER);
- System.out.println(imageCaptchaInfo);
-
- // 负责计算一些数据存到缓存中,用于校验使用
- // ImageCaptchaValidator负责校验用户滑动滑块是否正确和生成滑块的一些校验数据; 比如滑块到凹槽的百分比值
- ImageCaptchaValidator imageCaptchaValidator = new BasicCaptchaTrackValidator();
- // 这个map数据应该存到缓存中,校验的时候需要用到该数据
- Map map = imageCaptchaValidator.generateImageCaptchaValidData(imageCaptchaInfo);
- }
-}
-
-```
-
-### 3. 使用`ImageCaptchaValidator`校验器 验证
-
-```java
-package example.readme;
-
-import cloud.tianai.captcha.validator.ImageCaptchaValidator;
-import cloud.tianai.captcha.validator.common.model.dto.ImageCaptchaTrack;
-import cloud.tianai.captcha.validator.impl.BasicCaptchaTrackValidator;
-
-import java.util.Map;
-
-public class Test2 {
- public static void main(String[] args) {
- ImageCaptchaValidator sliderCaptchaValidator = new BasicCaptchaTrackValidator();
-
- ImageCaptchaTrack imageCaptchaTrack = null;
- Map map = null;
- Float percentage = null;
- // 用户传来的行为轨迹和进行校验
- // - imageCaptchaTrack为前端传来的滑动轨迹数据
- // - map 为生成验证码时缓存的map数据
- boolean check = sliderCaptchaValidator.valid(imageCaptchaTrack, map);
- // 如果只想校验用户是否滑到指定凹槽即可,也可以使用
- // - 参数1 用户传来的百分比数据
- // - 参数2 生成滑块是真实的百分比数据
- check = sliderCaptchaValidator.checkPercentage(0.2f, percentage);
- }
-}
-
-```
-
-## 整体架构设计
-
-> tianai-captcha 验证码整体分为 生成器(`ImageCaptchaGenerator`)、校验器(`ImageCaptchaValidator`)、资源管理器(`ImageCaptchaResourceManager`)
-> 其中生成器、校验器、资源管理器等都是基于接口模式实现 可插拔的,可以替换为自定义实现,灵活度高
-
-- 生成器(`ImageCaptchaGenerator`)
- - 主要负责生成行为验证码所需的图片
-- 校验器(`ImageCaptchaValidator`)
- - 主要负责校验用户滑动的行为轨迹是否合规
-- 资源管理器(`ImageCaptchaResourceManager`)
- - 主要负责读取验证码背景图片和模板图片等
- - 资源管理器细分为 资源存储(`ResourceStore`)、资源提供者(`ResourceProvider`)
- - 资源存储(`ResourceStore`) 负责存储背景图和模板图
- - 资源提供者(`ResourceProvider`) 负责将资源存储器中对应的资源转换为文件流
- - 一般资源存储器中存储的是图片的url地址或者id之类, 资源提供者 就是负责将url或者别的id转换为真正的图片文件
-
-## 扩展
-
-### 生成带有混淆滑块的图片
-
-```java
-package example.readme;
-
-import cloud.tianai.captcha.common.constant.CaptchaTypeConstant;
-import cloud.tianai.captcha.generator.ImageCaptchaGenerator;
-import cloud.tianai.captcha.generator.common.model.dto.GenerateParam;
-import cloud.tianai.captcha.generator.common.model.dto.ImageCaptchaInfo;
-import cloud.tianai.captcha.generator.impl.MultiImageCaptchaGenerator;
-import cloud.tianai.captcha.resource.ImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.impl.DefaultImageCaptchaResourceManager;
-
-public class Test3 {
- public static void main(String[] args) {
- // 资源管理器
- ImageCaptchaResourceManager imageCaptchaResourceManager = new DefaultImageCaptchaResourceManager();
- // 标准验证码生成器
- ImageCaptchaGenerator imageCaptchaGenerator = new MultiImageCaptchaGenerator(imageCaptchaResourceManager).init(true);
- // 生成 具有混淆的 滑块验证码 (目前只有滑块验证码支持混淆滑块, 旋转验证,滑动还原,点选验证 均不支持混淆功能)
- ImageCaptchaInfo imageCaptchaInfo = imageCaptchaGenerator.generateCaptchaImage(GenerateParam.builder()
- .type(CaptchaTypeConstant.SLIDER)
- .sliderFormatName("jpeg")
- .backgroundFormatName("png")
- // 是否添加混淆滑块
- .obfuscate(true)
- .build());
- }
-}
-
-```
-
-### 生成webp格式的滑块图片
-
-```java
-package example.readme;
-
-import cloud.tianai.captcha.common.constant.CaptchaTypeConstant;
-import cloud.tianai.captcha.generator.ImageCaptchaGenerator;
-import cloud.tianai.captcha.generator.common.model.dto.GenerateParam;
-import cloud.tianai.captcha.generator.common.model.dto.ImageCaptchaInfo;
-import cloud.tianai.captcha.generator.impl.MultiImageCaptchaGenerator;
-import cloud.tianai.captcha.resource.ImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.impl.DefaultImageCaptchaResourceManager;
-
-public class Test4 {
- public static void main(String[] args) {
- // 资源管理器
- ImageCaptchaResourceManager imageCaptchaResourceManager = new DefaultImageCaptchaResourceManager();
- // 标准验证码生成器
- ImageCaptchaGenerator imageCaptchaGenerator = new MultiImageCaptchaGenerator(imageCaptchaResourceManager).init(true);
- // 生成旋转验证码 图片类型为 webp
- // 注意 tianai-captcha-1.3.2 后面默认删除了生成webp格式图片需要用户自定义添加webp转换的工具,需要用户自定义添加和扩展
- // 参考 https://bitbucket.org/luciad/webp-imageio
- ImageCaptchaInfo slideImageInfo = imageCaptchaGenerator.generateCaptchaImage(GenerateParam.builder()
- .type(CaptchaTypeConstant.ROTATE)
- .sliderFormatName("webp")
- .backgroundFormatName("webp")
- .build());
- System.out.println(slideImageInfo);
- }
-}
-
-```
-
-### 添加自定义图片资源
-
-- 自定义图片资源大小为 590*360 格式为jpg
-
-```java
-package example.readme;
-
-import cloud.tianai.captcha.common.constant.CaptchaTypeConstant;
-import cloud.tianai.captcha.resource.ImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.ResourceStore;
-import cloud.tianai.captcha.resource.common.model.dto.Resource;
-import cloud.tianai.captcha.resource.impl.DefaultImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.impl.provider.ClassPathResourceProvider;
-import cloud.tianai.captcha.resource.impl.provider.URLResourceProvider;
-
-public class Test5 {
- public static void main(String[] args) {
- ImageCaptchaResourceManager imageCaptchaResourceManager = new DefaultImageCaptchaResourceManager();
- // 通过资源管理器或者资源存储器
- ResourceStore resourceStore = imageCaptchaResourceManager.getResourceStore();
- // 添加classpath目录下的 aa.jpg 图片
- resourceStore.addResource(CaptchaTypeConstant.SLIDER, new Resource(ClassPathResourceProvider.NAME, "/aa.jpg"));
- // 添加远程url图片资源
- resourceStore.addResource(CaptchaTypeConstant.SLIDER,new Resource(URLResourceProvider.NAME, "http://www.xx.com/aa.jpg"));
- // 内置了通过url 和 classpath读取图片资源,如果想扩展可实现 ResourceProvider 接口,进行自定义扩展
- }
-}
-
-```
-
-### 添加自定义模板资源
-
-- 系统内置了2套模板,可以到QQ群:1021884609 文件中获取更多模板或者自己制作模板
-- 模板图片格式
- - 滑块验证码
- - 滑块大小为 110*110 格式为png
- - 凹槽大小为 110*110 格式为png
- - 模板大小为 110*360 格式为png,该图为固定格式,是一张纯透明图片
- - 旋转验证码
- - 滑块大小为 200*200 格式为png
- - 凹槽大小为 200*200 格式为png
- - 模板大小为 360*360 格式为png,该图为固定格式,是一张纯透明图片
-```java
-package example.readme;
-
-import cloud.tianai.captcha.common.constant.CaptchaTypeConstant;
-import cloud.tianai.captcha.generator.common.constant.SliderCaptchaConstant;
-import cloud.tianai.captcha.resource.ImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.ResourceStore;
-import cloud.tianai.captcha.resource.common.model.dto.Resource;
-import cloud.tianai.captcha.resource.impl.DefaultImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.impl.provider.ClassPathResourceProvider;
-
-import java.util.HashMap;
-import java.util.Map;
-
-public class Test6 {
- public static void main(String[] args) {
- ImageCaptchaResourceManager imageCaptchaResourceManager = new DefaultImageCaptchaResourceManager();
- // 通过资源管理器或者资源存储器
- ResourceStore resourceStore = imageCaptchaResourceManager.getResourceStore();
- // 添加滑块验证码模板.模板图片由三张图片组成
- Map template1 = new HashMap<>(4);
- template1.put(SliderCaptchaConstant.TEMPLATE_ACTIVE_IMAGE_NAME, new Resource(ClassPathResourceProvider.NAME, "/active.png"));
- template1.put(SliderCaptchaConstant.TEMPLATE_FIXED_IMAGE_NAME, new Resource(ClassPathResourceProvider.NAME, "/fixed.png"));
- template1.put(SliderCaptchaConstant.TEMPLATE_MATRIX_IMAGE_NAME, new Resource(ClassPathResourceProvider.NAME, "/matrix.png"));
- resourceStore.addTemplate(CaptchaTypeConstant.SLIDER,template1);
- // 模板与三张图片组成 滑块、凹槽、背景图
- // 同样默认支持 classpath 和 url 两种获取图片资源, 如果想扩展可实现 ResourceProvider 接口,进行自定义扩展
- }
+ System.out.println(slideImageInfo);
}
```
+# 常用接口
+- 添加自定义图片资源
+```java
+ ResourceStore resourceStore = sliderCaptchaResourceManager.getResourceStore();=
+ // 添加classpath目录下的 aa.jpg 图片
+ resourceStore.addResource(new Resource(ClassPathResourceProvider.NAME, "/aa.jpg"));
+ // 添加远程url图片资源
+ resourceStore.addResource(new Resource(URLResourceProvider.NAME, "http://www.xx.com/aa.jpg"));
+ // 内置了通过url 和 classpath读取图片资源,如果想扩展可实现 ResourceProvider 接口,进行自定义扩展
+```
+- 添加自定义模板资源
+```java
+ ResourceStore resourceStore = sliderCaptchaResourceManager.getResourceStore();=
+ Map template1 = new HashMap<>(4);
+ template1.put(SliderCaptchaConstant.TEMPLATE_ACTIVE_IMAGE_NAME, new Resource(ClassPathResourceProvider.NAME,"/active.png"));
+ template1.put(SliderCaptchaConstant.TEMPLATE_FIXED_IMAGE_NAME, new Resource(ClassPathResourceProvider.NAME, "/fixed.png"));
+ template1.put(SliderCaptchaConstant.TEMPLATE_MATRIX_IMAGE_NAME, new Resource(ClassPathResourceProvider.NAME, "/matrix.png"));
+ resourceStore.addTemplate(template1);
+ // 模板与三张图片组成 滑块、凹槽、背景图
+ // 同样默认支持 classpath 和 url 两种获取图片资源, 如果想扩展可实现 ResourceProvider 接口,进行自定义扩展
+```
- 清除内置的图片资源和模板资源
-
```java
-package example.readme;
-
-import cloud.tianai.captcha.generator.ImageCaptchaGenerator;
-import cloud.tianai.captcha.generator.impl.MultiImageCaptchaGenerator;
-import cloud.tianai.captcha.resource.ImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.impl.DefaultImageCaptchaResourceManager;
-
-public class Test6 {
- public static void main(String[] args) {
- ImageCaptchaResourceManager imageCaptchaResourceManager = new DefaultImageCaptchaResourceManager();
- //为方便快速上手 系统本身自带了一张图片和两套滑块模板,如果不想用系统自带的可以不让它加载系统自带的
- // 第二个构造参数设置为false时将不加载默认的图片和模板
- ImageCaptchaGenerator imageCaptchaGenerator = new MultiImageCaptchaGenerator(imageCaptchaResourceManager).init(false);
- }
-}
-
- ```
-
-### 自定义 `imageCaptchaValidator` 校验器
-
-```java
-// 该接口负责对用户滑动验证码后传回的数据进行校验,比如滑块是否滑到指定位置,滑块行为轨迹是否正常等等
-// 该接口的默认实现有
-// SimpleImageCaptchaValidator 校验用户是否滑到了指定缺口处
-// BasicCaptchaTrackValidator 是对 SimpleImageCaptchaValidator增强
-// BasicCaptchaTrackValidator是对SimpleImageCaptchaValidator的增强 对滑动轨迹进行了简单的验证
-// 友情提示 因为BasicCaptchaTrackValidator 里面校验滑动轨迹的算法已经开源,有强制要求的建议重写该接口的方法,避免被破解
+ //为方便快速上手 系统本身自带了一张图片和两套滑块模板,如果不想用系统自带的可以不让它加载系统自带的
+ // 第二个构造参数设置为false时将不加载默认的图片和模板
+ SliderCaptchaTemplate sliderCaptchaTemplate = new DefaultSliderCaptchaTemplate(sliderCaptchaResourceManager, false);
```
-
-### 自定义 `ResourceProvider` 实现自定义文件读取策略, 比如 oss之类的
-
+- 扩展,对`DefaultSliderCaptchaTemplate`增加了缓存模块
```java
-package example.readme;
+public static void main(String[] args) throws InterruptedException {
+ // 使用 CacheSliderCaptchaTemplate 对滑块验证码进行缓存,使其提前生成滑块图片
+ // 参数一: 真正实现 滑块的 SliderCaptchaTemplate
+ // 参数二: 默认提前缓存多少个
+ // 参数三: 出错后 等待xx时间再进行生成
+ // 参数四: 检查时间间隔
+ SliderCaptchaResourceManager sliderCaptchaResourceManager = new DefaultSliderCaptchaResourceManager();
+ DefaultSliderCaptchaTemplate sliderCaptchaTemplate = new CacheSliderCaptchaTemplate(new DefaultSliderCaptchaTemplate(sliderCaptchaResourceManager, true), 10, 1000, 100);
+ // 生成滑块图片
+ SliderCaptchaInfo slideImageInfo = sliderCaptchaTemplate.getSlideImageInfo();
+ // 获取背景图片的base64
+ String backgroundImage = slideImageInfo.getBackgroundImage();
+ // 获取滑块图片
+ slideImageInfo.getSliderImage();
+ // 获取滑块被背景图片的百分比, (校验图片使用)
+ Float xPercent = slideImageInfo.getXPercent();
-import cloud.tianai.captcha.generator.ImageCaptchaGenerator;
-import cloud.tianai.captcha.generator.impl.MultiImageCaptchaGenerator;
-import cloud.tianai.captcha.resource.ImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.ResourceProvider;
-import cloud.tianai.captcha.resource.common.model.dto.Resource;
-import cloud.tianai.captcha.resource.impl.DefaultImageCaptchaResourceManager;
-
-import java.io.InputStream;
-
-public class Test7 {
- public static void main(String[] args) {
- // 自定义 ResourceProvider
- ResourceProvider resourceProvider = new ResourceProvider() {
- @Override
- public InputStream getResourceInputStream(Resource data) {
- return null;
- }
-
- @Override
- public boolean supported(String type) {
- return false;
- }
-
- @Override
- public String getName() {
- return null;
- }
- };
- ImageCaptchaResourceManager imageCaptchaResourceManager = new DefaultImageCaptchaResourceManager();
- ImageCaptchaGenerator imageCaptchaGenerator = new MultiImageCaptchaGenerator(imageCaptchaResourceManager).init(false);
- // 注册
- imageCaptchaResourceManager.registerResourceProvider(resourceProvider);
- }
-}
-
-```
-
-### 扩展,对`StandardImageCaptchaGenerator`增加了缓存模块
-
-> 由于实时生成滑块图片可能会有一点性能影响,内部基于`StandardSliderCaptchaGenerator`进行了提前缓存生成好的图片,`CacheSliderCaptchaGenerator` 这只是基本的缓存逻辑,比较简单,用户可以定义一些更加有意思的扩展,用于突破性能瓶颈
-
-```java
-package example.readme;
-
-import cloud.tianai.captcha.common.constant.CaptchaTypeConstant;
-import cloud.tianai.captcha.generator.ImageCaptchaGenerator;
-import cloud.tianai.captcha.generator.common.model.dto.ImageCaptchaInfo;
-import cloud.tianai.captcha.generator.impl.CacheImageCaptchaGenerator;
-import cloud.tianai.captcha.generator.impl.MultiImageCaptchaGenerator;
-import cloud.tianai.captcha.resource.ImageCaptchaResourceManager;
-import cloud.tianai.captcha.resource.impl.DefaultImageCaptchaResourceManager;
-
-public class Test8 {
- public static void main(String[] args) throws InterruptedException {
- // 使用 CacheSliderCaptchaGenerator 对滑块验证码进行缓存,使其提前生成滑块图片
- // 参数一: 真正实现 滑块的 SliderCaptchaGenerator
- // 参数二: 默认提前缓存多少个
- // 参数三: 出错后 等待xx时间再进行生成
- // 参数四: 检查时间间隔
- ImageCaptchaResourceManager imageCaptchaResourceManager = new DefaultImageCaptchaResourceManager();
- ImageCaptchaGenerator imageCaptchaGenerator = new CacheImageCaptchaGenerator(new MultiImageCaptchaGenerator(imageCaptchaResourceManager), 10, 1000, 100);
- imageCaptchaGenerator.init(true);
- // 生成滑块图片
- ImageCaptchaInfo slideImageInfo = imageCaptchaGenerator.generateCaptchaImage(CaptchaTypeConstant.SLIDER);
- // 获取背景图片的base64
- String backgroundImage = slideImageInfo.getBackgroundImage();
- // 获取滑块图片
- String sliderImage = slideImageInfo.getSliderImage();
- System.out.println(slideImageInfo);
- }
+ System.out.println(slideImageInfo);
}
```
-# qq群: 1021884609
+- 自定义 `ResourceProvider` 实现自定义文件读取策略, 比如 oss之类的
+
+```java
+ // 实现了 ResourceProvider 后
+ SliderCaptchaResourceManager sliderCaptchaResourceManager = new DefaultSliderCaptchaResourceManager();
+ DefaultSliderCaptchaTemplate sliderCaptchaTemplate = new DefaultSliderCaptchaTemplate(sliderCaptchaResourceManager, true);
+ // 注册
+ sliderCaptchaResourceManager.registerResourceProvider(new CustomResourceProvider());
+```
+- qq群: 1021884609
\ No newline at end of file